diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/TestgeneratorDSLParser.java b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/TestgeneratorDSLParser.java
index 6d9fe51d809b43c09a07984a6faf8c6ccf373dae..e2e8c42a4c7b4df33908c5b1e1d4fa9ac54e31b9 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/TestgeneratorDSLParser.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/TestgeneratorDSLParser.java
@@ -55,45 +55,18 @@ public class TestgeneratorDSLParser extends AbstractContentAssistParser {
 			builder.put(grammarAccess.getBPMNDiagramAccess().getGroup_12_4_1(), "rule__BPMNDiagram__Group_12_4_1__0");
 			builder.put(grammarAccess.getStartFlowElementAccess().getGroup(), "rule__StartFlowElement__Group__0");
 			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_4(), "rule__StartFlowElement__Group_4__0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_4_5(), "rule__StartFlowElement__Group_4_5__0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_4_5_1(), "rule__StartFlowElement__Group_4_5_1__0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_5(), "rule__StartFlowElement__Group_5__0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_5_4(), "rule__StartFlowElement__Group_5_4__0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_5_4_1(), "rule__StartFlowElement__Group_5_4_1__0");
+			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_4_4(), "rule__StartFlowElement__Group_4_4__0");
+			builder.put(grammarAccess.getStartFlowElementAccess().getGroup_4_4_1(), "rule__StartFlowElement__Group_4_4_1__0");
 			builder.put(grammarAccess.getEndFlowElementAccess().getGroup(), "rule__EndFlowElement__Group__0");
 			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup(), "rule__UserTaskFlowElement__Group__0");
 			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_4(), "rule__UserTaskFlowElement__Group_4__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5(), "rule__UserTaskFlowElement__Group_4_5__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5_1(), "rule__UserTaskFlowElement__Group_4_5_1__0");
+			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4(), "rule__UserTaskFlowElement__Group_4_4__0");
+			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4_1(), "rule__UserTaskFlowElement__Group_4_4_1__0");
 			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_5(), "rule__UserTaskFlowElement__Group_5__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4(), "rule__UserTaskFlowElement__Group_5_4__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4_1(), "rule__UserTaskFlowElement__Group_5_4_1__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_6(), "rule__UserTaskFlowElement__Group_6__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4(), "rule__UserTaskFlowElement__Group_6_4__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4_1(), "rule__UserTaskFlowElement__Group_6_4_1__0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getGroup_7(), "rule__UserTaskFlowElement__Group_7__0");
 			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup(), "rule__ManualTaskFlowElement__Group__0");
 			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_4(), "rule__ManualTaskFlowElement__Group_4__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5(), "rule__ManualTaskFlowElement__Group_4_5__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5_1(), "rule__ManualTaskFlowElement__Group_4_5_1__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_5(), "rule__ManualTaskFlowElement__Group_5__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4(), "rule__ManualTaskFlowElement__Group_5_4__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4_1(), "rule__ManualTaskFlowElement__Group_5_4_1__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_6(), "rule__ManualTaskFlowElement__Group_6__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4(), "rule__ManualTaskFlowElement__Group_6_4__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4_1(), "rule__ManualTaskFlowElement__Group_6_4_1__0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getGroup_7(), "rule__ManualTaskFlowElement__Group_7__0");
 			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup(), "rule__ScriptTaskFlowElement__Group__0");
 			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4(), "rule__ScriptTaskFlowElement__Group_4__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5(), "rule__ScriptTaskFlowElement__Group_4_5__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5_1(), "rule__ScriptTaskFlowElement__Group_4_5_1__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5(), "rule__ScriptTaskFlowElement__Group_5__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4(), "rule__ScriptTaskFlowElement__Group_5_4__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4_1(), "rule__ScriptTaskFlowElement__Group_5_4_1__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6(), "rule__ScriptTaskFlowElement__Group_6__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4(), "rule__ScriptTaskFlowElement__Group_6_4__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4_1(), "rule__ScriptTaskFlowElement__Group_6_4_1__0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getGroup_7(), "rule__ScriptTaskFlowElement__Group_7__0");
 			builder.put(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup(), "rule__DelegateServiceTaskFlowElement__Group__0");
 			builder.put(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8(), "rule__DelegateServiceTaskFlowElement__Group_8__0");
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup(), "rule__ExternalServiceTaskFlowElement__Group__0");
@@ -101,27 +74,14 @@ public class TestgeneratorDSLParser extends AbstractContentAssistParser {
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5(), "rule__ExternalServiceTaskFlowElement__Group_8_5__0");
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1(), "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0");
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9(), "rule__ExternalServiceTaskFlowElement__Group_9__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4(), "rule__ExternalServiceTaskFlowElement__Group_9_4__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4_1(), "rule__ExternalServiceTaskFlowElement__Group_9_4_1__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10(), "rule__ExternalServiceTaskFlowElement__Group_10__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4(), "rule__ExternalServiceTaskFlowElement__Group_10_4__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4_1(), "rule__ExternalServiceTaskFlowElement__Group_10_4_1__0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_11(), "rule__ExternalServiceTaskFlowElement__Group_11__0");
 			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup(), "rule__BusinessRuleTaskFlowElement__Group__0");
 			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4(), "rule__BusinessRuleTaskFlowElement__Group_4__0");
 			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5(), "rule__BusinessRuleTaskFlowElement__Group_5__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5(), "rule__BusinessRuleTaskFlowElement__Group_5_5__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5_1(), "rule__BusinessRuleTaskFlowElement__Group_5_5_1__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6(), "rule__BusinessRuleTaskFlowElement__Group_6__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4(), "rule__BusinessRuleTaskFlowElement__Group_6_4__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4_1(), "rule__BusinessRuleTaskFlowElement__Group_6_4_1__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7(), "rule__BusinessRuleTaskFlowElement__Group_7__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4(), "rule__BusinessRuleTaskFlowElement__Group_7_4__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4_1(), "rule__BusinessRuleTaskFlowElement__Group_7_4_1__0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_8(), "rule__BusinessRuleTaskFlowElement__Group_8__0");
 			builder.put(grammarAccess.getGatewayFlowElementAccess().getGroup(), "rule__GatewayFlowElement__Group__0");
 			builder.put(grammarAccess.getSequenceFlowElementAccess().getGroup(), "rule__SequenceFlowElement__Group__0");
 			builder.put(grammarAccess.getSequenceFlowElementAccess().getGroup_4(), "rule__SequenceFlowElement__Group_4__0");
+			builder.put(grammarAccess.getFlowElementReferenceAccess().getGroup(), "rule__FlowElementReference__Group__0");
+			builder.put(grammarAccess.getFlowElementReferenceAccess().getGroup_1(), "rule__FlowElementReference__Group_1__0");
 			builder.put(grammarAccess.getExternalTopicAccess().getGroup(), "rule__ExternalTopic__Group__0");
 			builder.put(grammarAccess.getStringVariableAccess().getGroup(), "rule__StringVariable__Group__0");
 			builder.put(grammarAccess.getStringVariableAccess().getGroup_6(), "rule__StringVariable__Group_6__0");
@@ -190,35 +150,17 @@ public class TestgeneratorDSLParser extends AbstractContentAssistParser {
 			builder.put(grammarAccess.getBPMNDiagramAccess().getEmbeddedAssignment_12_4_1_1(), "rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1");
 			builder.put(grammarAccess.getBPMNReferenceAccess().getRefAssignment(), "rule__BPMNReference__RefAssignment");
 			builder.put(grammarAccess.getStartFlowElementAccess().getNameAssignment_1(), "rule__StartFlowElement__NameAssignment_1");
-			builder.put(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_0(), "rule__StartFlowElement__HardcodedInputsAssignment_4_5_0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1(), "rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1");
-			builder.put(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_0(), "rule__StartFlowElement__StartVariablesAssignment_5_4_0");
-			builder.put(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_1_1(), "rule__StartFlowElement__StartVariablesAssignment_5_4_1_1");
+			builder.put(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_0(), "rule__StartFlowElement__InputVariablesAssignment_4_4_0");
+			builder.put(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_1_1(), "rule__StartFlowElement__InputVariablesAssignment_4_4_1_1");
 			builder.put(grammarAccess.getEndFlowElementAccess().getNameAssignment_1(), "rule__EndFlowElement__NameAssignment_1");
 			builder.put(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1(), "rule__UserTaskFlowElement__NameAssignment_1");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0(), "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1(), "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_0(), "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1(), "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0(), "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1(), "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1");
-			builder.put(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_7_3(), "rule__UserTaskFlowElement__LabelAssignment_7_3");
+			builder.put(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_0(), "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0");
+			builder.put(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_1_1(), "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1");
+			builder.put(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_5_3(), "rule__UserTaskFlowElement__LabelAssignment_5_3");
 			builder.put(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1(), "rule__ManualTaskFlowElement__NameAssignment_1");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0(), "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1(), "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_0(), "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1(), "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0(), "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1(), "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1");
-			builder.put(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_7_3(), "rule__ManualTaskFlowElement__LabelAssignment_7_3");
+			builder.put(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_4_3(), "rule__ManualTaskFlowElement__LabelAssignment_4_3");
 			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1(), "rule__ScriptTaskFlowElement__NameAssignment_1");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0(), "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1(), "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_0(), "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1(), "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0(), "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1(), "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1");
-			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_7_3(), "rule__ScriptTaskFlowElement__LabelAssignment_7_3");
+			builder.put(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_4_3(), "rule__ScriptTaskFlowElement__LabelAssignment_4_3");
 			builder.put(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1(), "rule__DelegateServiceTaskFlowElement__NameAssignment_1");
 			builder.put(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7(), "rule__DelegateServiceTaskFlowElement__DelegateAssignment_7");
 			builder.put(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3(), "rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3");
@@ -226,24 +168,15 @@ public class TestgeneratorDSLParser extends AbstractContentAssistParser {
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7(), "rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7");
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0(), "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0");
 			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1(), "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_0(), "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_1_1(), "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_0(), "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_1_1(), "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1");
-			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_11_3(), "rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3");
+			builder.put(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_9_3(), "rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3");
 			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1(), "rule__BusinessRuleTaskFlowElement__NameAssignment_1");
 			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3(), "rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_0(), "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_1_1(), "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_0(), "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_1_1(), "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_0(), "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_1_1(), "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1");
-			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_8_3(), "rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3");
+			builder.put(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_5_3(), "rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3");
 			builder.put(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1(), "rule__GatewayFlowElement__NameAssignment_1");
 			builder.put(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1(), "rule__SequenceFlowElement__NameAssignment_1");
 			builder.put(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3(), "rule__SequenceFlowElement__ExpressionAssignment_4_3");
-			builder.put(grammarAccess.getFlowElementReferenceAccess().getRefAssignment(), "rule__FlowElementReference__RefAssignment");
+			builder.put(grammarAccess.getFlowElementReferenceAccess().getRefAssignment_0(), "rule__FlowElementReference__RefAssignment_0");
+			builder.put(grammarAccess.getFlowElementReferenceAccess().getFlagAssignment_1_1(), "rule__FlowElementReference__FlagAssignment_1_1");
 			builder.put(grammarAccess.getDelegateServiceTaskReferenceAccess().getRefAssignment(), "rule__DelegateServiceTaskReference__RefAssignment");
 			builder.put(grammarAccess.getExternalTopicAccess().getNameAssignment_1(), "rule__ExternalTopic__NameAssignment_1");
 			builder.put(grammarAccess.getExternalTopicReferenceAccess().getRefAssignment(), "rule__ExternalTopicReference__RefAssignment");
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.g b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.g
index c5743f8ef1747eb731f759840fcfd692fdc5beb7..2b50b4f211cff0b4697288bd126e5eac638b230f 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.g
+++ b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.g
@@ -465,9 +465,9 @@ ruleFlowElementReference
 	}
 	:
 	(
-		{ before(grammarAccess.getFlowElementReferenceAccess().getRefAssignment()); }
-		(rule__FlowElementReference__RefAssignment)
-		{ after(grammarAccess.getFlowElementReferenceAccess().getRefAssignment()); }
+		{ before(grammarAccess.getFlowElementReferenceAccess().getGroup()); }
+		(rule__FlowElementReference__Group__0)
+		{ after(grammarAccess.getFlowElementReferenceAccess().getGroup()); }
 	)
 ;
 finally {
@@ -1911,21 +1911,27 @@ rule__Flag__Alternatives
 	}
 :
 	(
-		{ before(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0()); }
+		{ before(grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0()); }
+		('NONE')
+		{ after(grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0()); }
+	)
+	|
+	(
+		{ before(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1()); }
 		('GREEN')
-		{ after(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0()); }
+		{ after(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1()); }
 	)
 	|
 	(
-		{ before(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1()); }
+		{ before(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2()); }
 		('YELLOW')
-		{ after(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1()); }
+		{ after(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2()); }
 	)
 	|
 	(
-		{ before(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2()); }
+		{ before(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3()); }
 		('RED')
-		{ after(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2()); }
+		{ after(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3()); }
 	)
 ;
 finally {
@@ -2991,7 +2997,6 @@ rule__StartFlowElement__Group__5
 	}
 :
 	rule__StartFlowElement__Group__5__Impl
-	rule__StartFlowElement__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
@@ -3003,35 +3008,9 @@ rule__StartFlowElement__Group__5__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getGroup_5()); }
-	(rule__StartFlowElement__Group_5__0)?
-	{ after(grammarAccess.getStartFlowElementAccess().getGroup_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StartFlowElement__Group__6__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
 	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
+	{ after(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
 )
 ;
 finally {
@@ -3084,9 +3063,9 @@ rule__StartFlowElement__Group_4__1__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getHardcodedKeyword_4_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getStartFlowElementAccess().getHardcodedKeyword_4_1()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getInputVariablesKeyword_4_1()); }
+	'inputVariables'
+	{ after(grammarAccess.getStartFlowElementAccess().getInputVariablesKeyword_4_1()); }
 )
 ;
 finally {
@@ -3111,9 +3090,9 @@ rule__StartFlowElement__Group_4__2__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getInputsKeyword_4_2()); }
-	'inputs'
-	{ after(grammarAccess.getStartFlowElementAccess().getInputsKeyword_4_2()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
@@ -3138,9 +3117,9 @@ rule__StartFlowElement__Group_4__3__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); }
 )
 ;
 finally {
@@ -3165,9 +3144,9 @@ rule__StartFlowElement__Group_4__4__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getGroup_4_4()); }
+	(rule__StartFlowElement__Group_4_4__0)?
+	{ after(grammarAccess.getStartFlowElementAccess().getGroup_4_4()); }
 )
 ;
 finally {
@@ -3180,7 +3159,6 @@ rule__StartFlowElement__Group_4__5
 	}
 :
 	rule__StartFlowElement__Group_4__5__Impl
-	rule__StartFlowElement__Group_4__6
 ;
 finally {
 	restoreStackSize(stackSize);
@@ -3192,980 +3170,981 @@ rule__StartFlowElement__Group_4__5__Impl
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getGroup_4_5()); }
-	(rule__StartFlowElement__Group_4_5__0)?
-	{ after(grammarAccess.getStartFlowElementAccess().getGroup_4_5()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4__6
+
+rule__StartFlowElement__Group_4_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_4__6__Impl
+	rule__StartFlowElement__Group_4_4__0__Impl
+	rule__StartFlowElement__Group_4_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4__6__Impl
+rule__StartFlowElement__Group_4_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_0()); }
+	(rule__StartFlowElement__InputVariablesAssignment_4_4_0)
+	{ after(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StartFlowElement__Group_4_5__0
+rule__StartFlowElement__Group_4_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_4_5__0__Impl
-	rule__StartFlowElement__Group_4_5__1
+	rule__StartFlowElement__Group_4_4__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5__0__Impl
+rule__StartFlowElement__Group_4_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
-	(rule__StartFlowElement__HardcodedInputsAssignment_4_5_0)
-	{ after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getGroup_4_4_1()); }
+	(rule__StartFlowElement__Group_4_4_1__0)*
+	{ after(grammarAccess.getStartFlowElementAccess().getGroup_4_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5__1
+
+rule__StartFlowElement__Group_4_4_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_4_5__1__Impl
+	rule__StartFlowElement__Group_4_4_1__0__Impl
+	rule__StartFlowElement__Group_4_4_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5__1__Impl
+rule__StartFlowElement__Group_4_4_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getGroup_4_5_1()); }
-	(rule__StartFlowElement__Group_4_5_1__0)*
-	{ after(grammarAccess.getStartFlowElementAccess().getGroup_4_5_1()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StartFlowElement__Group_4_5_1__0
+rule__StartFlowElement__Group_4_4_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_4_5_1__0__Impl
-	rule__StartFlowElement__Group_4_5_1__1
+	rule__StartFlowElement__Group_4_4_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5_1__0__Impl
+rule__StartFlowElement__Group_4_4_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
+	{ before(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); }
+	(rule__StartFlowElement__InputVariablesAssignment_4_4_1_1)
+	{ after(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5_1__1
+
+rule__EndFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_4_5_1__1__Impl
+	rule__EndFlowElement__Group__0__Impl
+	rule__EndFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_4_5_1__1__Impl
+rule__EndFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
-	(rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1)
-	{ after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
+	{ before(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StartFlowElement__Group_5__0
+rule__EndFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__0__Impl
-	rule__StartFlowElement__Group_5__1
+	rule__EndFlowElement__Group__1__Impl
+	rule__EndFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__0__Impl
+rule__EndFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getWithKeyword_5_0()); }
-	'with'
-	{ after(grammarAccess.getStartFlowElementAccess().getWithKeyword_5_0()); }
+	{ before(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); }
+	(rule__EndFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__1
+rule__EndFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__1__Impl
-	rule__StartFlowElement__Group_5__2
+	rule__EndFlowElement__Group__2__Impl
+	rule__EndFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__1__Impl
+rule__EndFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getStartVariablesKeyword_5_1()); }
-	'startVariables'
-	{ after(grammarAccess.getStartFlowElementAccess().getStartVariablesKeyword_5_1()); }
+	{ before(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__2
+rule__EndFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__2__Impl
-	rule__StartFlowElement__Group_5__3
+	rule__EndFlowElement__Group__3__Impl
+	rule__EndFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__2__Impl
+rule__EndFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	{ before(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); }
+	'EndEvent'
+	{ after(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__3
+rule__EndFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__3__Impl
-	rule__StartFlowElement__Group_5__4
+	rule__EndFlowElement__Group__4__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__3__Impl
+rule__EndFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
+	{ before(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__4
+
+rule__UserTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__4__Impl
-	rule__StartFlowElement__Group_5__5
+	rule__UserTaskFlowElement__Group__0__Impl
+	rule__UserTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__4__Impl
+rule__UserTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getGroup_5_4()); }
-	(rule__StartFlowElement__Group_5_4__0)?
-	{ after(grammarAccess.getStartFlowElementAccess().getGroup_5_4()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__5
+rule__UserTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5__5__Impl
+	rule__UserTaskFlowElement__Group__1__Impl
+	rule__UserTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5__5__Impl
+rule__UserTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__UserTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StartFlowElement__Group_5_4__0
+rule__UserTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5_4__0__Impl
-	rule__StartFlowElement__Group_5_4__1
+	rule__UserTaskFlowElement__Group__2__Impl
+	rule__UserTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4__0__Impl
+rule__UserTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_0()); }
-	(rule__StartFlowElement__StartVariablesAssignment_5_4_0)
-	{ after(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_0()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4__1
+rule__UserTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5_4__1__Impl
+	rule__UserTaskFlowElement__Group__3__Impl
+	rule__UserTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4__1__Impl
+rule__UserTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getGroup_5_4_1()); }
-	(rule__StartFlowElement__Group_5_4_1__0)*
-	{ after(grammarAccess.getStartFlowElementAccess().getGroup_5_4_1()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); }
+	'UserTask'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StartFlowElement__Group_5_4_1__0
+rule__UserTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5_4_1__0__Impl
-	rule__StartFlowElement__Group_5_4_1__1
+	rule__UserTaskFlowElement__Group__4__Impl
+	rule__UserTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4_1__0__Impl
+rule__UserTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); }
+	(rule__UserTaskFlowElement__Group_4__0)?
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4_1__1
+rule__UserTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StartFlowElement__Group_5_4_1__1__Impl
+	rule__UserTaskFlowElement__Group__5__Impl
+	rule__UserTaskFlowElement__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StartFlowElement__Group_5_4_1__1__Impl
+rule__UserTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_1_1()); }
-	(rule__StartFlowElement__StartVariablesAssignment_5_4_1_1)
-	{ after(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_1_1()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); }
+	(rule__UserTaskFlowElement__Group_5__0)?
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__EndFlowElement__Group__0
+rule__UserTaskFlowElement__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__EndFlowElement__Group__0__Impl
-	rule__EndFlowElement__Group__1
+	rule__UserTaskFlowElement__Group__6__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__0__Impl
+rule__UserTaskFlowElement__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__1
+
+rule__UserTaskFlowElement__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__EndFlowElement__Group__1__Impl
-	rule__EndFlowElement__Group__2
+	rule__UserTaskFlowElement__Group_4__0__Impl
+	rule__UserTaskFlowElement__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__1__Impl
+rule__UserTaskFlowElement__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); }
-	(rule__EndFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); }
+	'with'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__2
+rule__UserTaskFlowElement__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__EndFlowElement__Group__2__Impl
-	rule__EndFlowElement__Group__3
+	rule__UserTaskFlowElement__Group_4__1__Impl
+	rule__UserTaskFlowElement__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__2__Impl
+rule__UserTaskFlowElement__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_4_1()); }
+	'inputVariables'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__3
+rule__UserTaskFlowElement__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__EndFlowElement__Group__3__Impl
-	rule__EndFlowElement__Group__4
+	rule__UserTaskFlowElement__Group_4__2__Impl
+	rule__UserTaskFlowElement__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__3__Impl
+rule__UserTaskFlowElement__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); }
-	'EndEvent'
-	{ after(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__4
+rule__UserTaskFlowElement__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__EndFlowElement__Group__4__Impl
+	rule__UserTaskFlowElement__Group_4__3__Impl
+	rule__UserTaskFlowElement__Group_4__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__EndFlowElement__Group__4__Impl
+rule__UserTaskFlowElement__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group__0
+rule__UserTaskFlowElement__Group_4__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__0__Impl
-	rule__UserTaskFlowElement__Group__1
+	rule__UserTaskFlowElement__Group_4__4__Impl
+	rule__UserTaskFlowElement__Group_4__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__0__Impl
+rule__UserTaskFlowElement__Group_4__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4()); }
+	(rule__UserTaskFlowElement__Group_4_4__0)?
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__1
+rule__UserTaskFlowElement__Group_4__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__1__Impl
-	rule__UserTaskFlowElement__Group__2
+	rule__UserTaskFlowElement__Group_4__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__1__Impl
+rule__UserTaskFlowElement__Group_4__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__UserTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__2
+
+rule__UserTaskFlowElement__Group_4_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__2__Impl
-	rule__UserTaskFlowElement__Group__3
+	rule__UserTaskFlowElement__Group_4_4__0__Impl
+	rule__UserTaskFlowElement__Group_4_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__2__Impl
+rule__UserTaskFlowElement__Group_4_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_0()); }
+	(rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0)
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__3
+rule__UserTaskFlowElement__Group_4_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__3__Impl
-	rule__UserTaskFlowElement__Group__4
+	rule__UserTaskFlowElement__Group_4_4__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__3__Impl
+rule__UserTaskFlowElement__Group_4_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); }
-	'UserTask'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4_1()); }
+	(rule__UserTaskFlowElement__Group_4_4_1__0)*
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__4
+
+rule__UserTaskFlowElement__Group_4_4_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__4__Impl
-	rule__UserTaskFlowElement__Group__5
+	rule__UserTaskFlowElement__Group_4_4_1__0__Impl
+	rule__UserTaskFlowElement__Group_4_4_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__4__Impl
+rule__UserTaskFlowElement__Group_4_4_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); }
-	(rule__UserTaskFlowElement__Group_4__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__5
+rule__UserTaskFlowElement__Group_4_4_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__5__Impl
-	rule__UserTaskFlowElement__Group__6
+	rule__UserTaskFlowElement__Group_4_4_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__5__Impl
+rule__UserTaskFlowElement__Group_4_4_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); }
-	(rule__UserTaskFlowElement__Group_5__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); }
+	(rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1)
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__6
+
+rule__UserTaskFlowElement__Group_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__6__Impl
-	rule__UserTaskFlowElement__Group__7
+	rule__UserTaskFlowElement__Group_5__0__Impl
+	rule__UserTaskFlowElement__Group_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__6__Impl
+rule__UserTaskFlowElement__Group_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6()); }
-	(rule__UserTaskFlowElement__Group_6__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_5_0()); }
+	'and'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__7
+rule__UserTaskFlowElement__Group_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__7__Impl
-	rule__UserTaskFlowElement__Group__8
+	rule__UserTaskFlowElement__Group_5__1__Impl
+	rule__UserTaskFlowElement__Group_5__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__7__Impl
+rule__UserTaskFlowElement__Group_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_7()); }
-	(rule__UserTaskFlowElement__Group_7__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_7()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_5_1()); }
+	'label'
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_5_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__8
+rule__UserTaskFlowElement__Group_5__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group__8__Impl
-;
+	rule__UserTaskFlowElement__Group_5__2__Impl
+	rule__UserTaskFlowElement__Group_5__3
+;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group__8__Impl
+rule__UserTaskFlowElement__Group_5__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group_4__0
+rule__UserTaskFlowElement__Group_5__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__0__Impl
-	rule__UserTaskFlowElement__Group_4__1
+	rule__UserTaskFlowElement__Group_5__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__0__Impl
+rule__UserTaskFlowElement__Group_5__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); }
+	{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_5_3()); }
+	(rule__UserTaskFlowElement__LabelAssignment_5_3)
+	{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_5_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__1
+
+rule__ManualTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__1__Impl
-	rule__UserTaskFlowElement__Group_4__2
+	rule__ManualTaskFlowElement__Group__0__Impl
+	rule__ManualTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__1__Impl
+rule__ManualTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__2
+rule__ManualTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__2__Impl
-	rule__UserTaskFlowElement__Group_4__3
+	rule__ManualTaskFlowElement__Group__1__Impl
+	rule__ManualTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__2__Impl
+rule__ManualTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputsKeyword_4_2()); }
-	'inputs'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputsKeyword_4_2()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__ManualTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__3
+rule__ManualTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__3__Impl
-	rule__UserTaskFlowElement__Group_4__4
+	rule__ManualTaskFlowElement__Group__2__Impl
+	rule__ManualTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__3__Impl
+rule__ManualTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__4
+rule__ManualTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__4__Impl
-	rule__UserTaskFlowElement__Group_4__5
+	rule__ManualTaskFlowElement__Group__3__Impl
+	rule__ManualTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__4__Impl
+rule__ManualTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); }
+	'ManualTask'
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__5
+rule__ManualTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__5__Impl
-	rule__UserTaskFlowElement__Group_4__6
+	rule__ManualTaskFlowElement__Group__4__Impl
+	rule__ManualTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__5__Impl
+rule__ManualTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5()); }
-	(rule__UserTaskFlowElement__Group_4_5__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); }
+	(rule__ManualTaskFlowElement__Group_4__0)?
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__6
+rule__ManualTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4__6__Impl
+	rule__ManualTaskFlowElement__Group__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4__6__Impl
+rule__ManualTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
 )
 ;
 finally {
@@ -4173,107 +4152,107 @@ finally {
 }
 
 
-rule__UserTaskFlowElement__Group_4_5__0
+rule__ManualTaskFlowElement__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4_5__0__Impl
-	rule__UserTaskFlowElement__Group_4_5__1
+	rule__ManualTaskFlowElement__Group_4__0__Impl
+	rule__ManualTaskFlowElement__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5__0__Impl
+rule__ManualTaskFlowElement__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
-	(rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_4_0()); }
+	'and'
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5__1
+rule__ManualTaskFlowElement__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4_5__1__Impl
+	rule__ManualTaskFlowElement__Group_4__1__Impl
+	rule__ManualTaskFlowElement__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5__1__Impl
+rule__ManualTaskFlowElement__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5_1()); }
-	(rule__UserTaskFlowElement__Group_4_5_1__0)*
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5_1()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_4_1()); }
+	'label'
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group_4_5_1__0
+rule__ManualTaskFlowElement__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4_5_1__0__Impl
-	rule__UserTaskFlowElement__Group_4_5_1__1
+	rule__ManualTaskFlowElement__Group_4__2__Impl
+	rule__ManualTaskFlowElement__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5_1__0__Impl
+rule__ManualTaskFlowElement__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5_1__1
+rule__ManualTaskFlowElement__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_4_5_1__1__Impl
+	rule__ManualTaskFlowElement__Group_4__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_4_5_1__1__Impl
+rule__ManualTaskFlowElement__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
-	(rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
+	{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_4_3()); }
+	(rule__ManualTaskFlowElement__LabelAssignment_4_3)
+	{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_4_3()); }
 )
 ;
 finally {
@@ -4281,161 +4260,161 @@ finally {
 }
 
 
-rule__UserTaskFlowElement__Group_5__0
+rule__ScriptTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__0__Impl
-	rule__UserTaskFlowElement__Group_5__1
+	rule__ScriptTaskFlowElement__Group__0__Impl
+	rule__ScriptTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__0__Impl
+rule__ScriptTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_5_0()); }
-	'with'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_5_0()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__1
+rule__ScriptTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__1__Impl
-	rule__UserTaskFlowElement__Group_5__2
+	rule__ScriptTaskFlowElement__Group__1__Impl
+	rule__ScriptTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__1__Impl
+rule__ScriptTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
-	'inputVariables'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__ScriptTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__2
+rule__ScriptTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__2__Impl
-	rule__UserTaskFlowElement__Group_5__3
+	rule__ScriptTaskFlowElement__Group__2__Impl
+	rule__ScriptTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__2__Impl
+rule__ScriptTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__3
+rule__ScriptTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__3__Impl
-	rule__UserTaskFlowElement__Group_5__4
+	rule__ScriptTaskFlowElement__Group__3__Impl
+	rule__ScriptTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__3__Impl
+rule__ScriptTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); }
+	'ScriptTask'
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__4
+rule__ScriptTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__4__Impl
-	rule__UserTaskFlowElement__Group_5__5
+	rule__ScriptTaskFlowElement__Group__4__Impl
+	rule__ScriptTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__4__Impl
+rule__ScriptTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4()); }
-	(rule__UserTaskFlowElement__Group_5_4__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); }
+	(rule__ScriptTaskFlowElement__Group_4__0)?
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__5
+rule__ScriptTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5__5__Impl
+	rule__ScriptTaskFlowElement__Group__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5__5__Impl
+rule__ScriptTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
 )
 ;
 finally {
@@ -4443,107 +4422,107 @@ finally {
 }
 
 
-rule__UserTaskFlowElement__Group_5_4__0
+rule__ScriptTaskFlowElement__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5_4__0__Impl
-	rule__UserTaskFlowElement__Group_5_4__1
+	rule__ScriptTaskFlowElement__Group_4__0__Impl
+	rule__ScriptTaskFlowElement__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4__0__Impl
+rule__ScriptTaskFlowElement__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
-	(rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_4_0()); }
+	'and'
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4__1
+rule__ScriptTaskFlowElement__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5_4__1__Impl
+	rule__ScriptTaskFlowElement__Group_4__1__Impl
+	rule__ScriptTaskFlowElement__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4__1__Impl
+rule__ScriptTaskFlowElement__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4_1()); }
-	(rule__UserTaskFlowElement__Group_5_4_1__0)*
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4_1()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_4_1()); }
+	'label'
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group_5_4_1__0
+rule__ScriptTaskFlowElement__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5_4_1__0__Impl
-	rule__UserTaskFlowElement__Group_5_4_1__1
+	rule__ScriptTaskFlowElement__Group_4__2__Impl
+	rule__ScriptTaskFlowElement__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4_1__0__Impl
+rule__ScriptTaskFlowElement__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4_1__1
+rule__ScriptTaskFlowElement__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_5_4_1__1__Impl
+	rule__ScriptTaskFlowElement__Group_4__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_5_4_1__1__Impl
+rule__ScriptTaskFlowElement__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
-	(rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
+	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_4_3()); }
+	(rule__ScriptTaskFlowElement__LabelAssignment_4_3)
+	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_4_3()); }
 )
 ;
 finally {
@@ -4551,269 +4530,269 @@ finally {
 }
 
 
-rule__UserTaskFlowElement__Group_6__0
+rule__DelegateServiceTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__0__Impl
-	rule__UserTaskFlowElement__Group_6__1
+	rule__DelegateServiceTaskFlowElement__Group__0__Impl
+	rule__DelegateServiceTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__0__Impl
+rule__DelegateServiceTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_6_0()); }
-	'with'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_6_0()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__1
+rule__DelegateServiceTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__1__Impl
-	rule__UserTaskFlowElement__Group_6__2
+	rule__DelegateServiceTaskFlowElement__Group__1__Impl
+	rule__DelegateServiceTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__1__Impl
+rule__DelegateServiceTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
-	'outputVariables'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__DelegateServiceTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__2
+rule__DelegateServiceTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__2__Impl
-	rule__UserTaskFlowElement__Group_6__3
+	rule__DelegateServiceTaskFlowElement__Group__2__Impl
+	rule__DelegateServiceTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__2__Impl
+rule__DelegateServiceTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__3
+rule__DelegateServiceTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__3__Impl
-	rule__UserTaskFlowElement__Group_6__4
+	rule__DelegateServiceTaskFlowElement__Group__3__Impl
+	rule__DelegateServiceTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__3__Impl
+rule__DelegateServiceTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
+	'ServiceTask'
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__4
+rule__DelegateServiceTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__4__Impl
-	rule__UserTaskFlowElement__Group_6__5
+	rule__DelegateServiceTaskFlowElement__Group__4__Impl
+	rule__DelegateServiceTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__4__Impl
+rule__DelegateServiceTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4()); }
-	(rule__UserTaskFlowElement__Group_6_4__0)?
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); }
+	'with'
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__5
+rule__DelegateServiceTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6__5__Impl
+	rule__DelegateServiceTaskFlowElement__Group__5__Impl
+	rule__DelegateServiceTaskFlowElement__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6__5__Impl
+rule__DelegateServiceTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); }
+	'delegate'
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group_6_4__0
+rule__DelegateServiceTaskFlowElement__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6_4__0__Impl
-	rule__UserTaskFlowElement__Group_6_4__1
+	rule__DelegateServiceTaskFlowElement__Group__6__Impl
+	rule__DelegateServiceTaskFlowElement__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4__0__Impl
+rule__DelegateServiceTaskFlowElement__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
-	(rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4__1
+rule__DelegateServiceTaskFlowElement__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6_4__1__Impl
+	rule__DelegateServiceTaskFlowElement__Group__7__Impl
+	rule__DelegateServiceTaskFlowElement__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4__1__Impl
+rule__DelegateServiceTaskFlowElement__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4_1()); }
-	(rule__UserTaskFlowElement__Group_6_4_1__0)*
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4_1()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); }
+	(rule__DelegateServiceTaskFlowElement__DelegateAssignment_7)
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__UserTaskFlowElement__Group_6_4_1__0
+rule__DelegateServiceTaskFlowElement__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6_4_1__0__Impl
-	rule__UserTaskFlowElement__Group_6_4_1__1
+	rule__DelegateServiceTaskFlowElement__Group__8__Impl
+	rule__DelegateServiceTaskFlowElement__Group__9
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4_1__0__Impl
+rule__DelegateServiceTaskFlowElement__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); }
+	(rule__DelegateServiceTaskFlowElement__Group_8__0)?
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4_1__1
+rule__DelegateServiceTaskFlowElement__Group__9
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_6_4_1__1__Impl
+	rule__DelegateServiceTaskFlowElement__Group__9__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_6_4_1__1__Impl
+rule__DelegateServiceTaskFlowElement__Group__9__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
-	(rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
 )
 ;
 finally {
@@ -4821,107 +4800,107 @@ finally {
 }
 
 
-rule__UserTaskFlowElement__Group_7__0
+rule__DelegateServiceTaskFlowElement__Group_8__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_7__0__Impl
-	rule__UserTaskFlowElement__Group_7__1
-;
+	rule__DelegateServiceTaskFlowElement__Group_8__0__Impl
+	rule__DelegateServiceTaskFlowElement__Group_8__1
+;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__0__Impl
+rule__DelegateServiceTaskFlowElement__Group_8__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_7_0()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); }
 	'and'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_7_0()); }
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__1
+rule__DelegateServiceTaskFlowElement__Group_8__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_7__1__Impl
-	rule__UserTaskFlowElement__Group_7__2
+	rule__DelegateServiceTaskFlowElement__Group_8__1__Impl
+	rule__DelegateServiceTaskFlowElement__Group_8__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__1__Impl
+rule__DelegateServiceTaskFlowElement__Group_8__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_7_1()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); }
 	'label'
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_7_1()); }
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__2
+rule__DelegateServiceTaskFlowElement__Group_8__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_7__2__Impl
-	rule__UserTaskFlowElement__Group_7__3
+	rule__DelegateServiceTaskFlowElement__Group_8__2__Impl
+	rule__DelegateServiceTaskFlowElement__Group_8__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__2__Impl
+rule__DelegateServiceTaskFlowElement__Group_8__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__3
+rule__DelegateServiceTaskFlowElement__Group_8__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__UserTaskFlowElement__Group_7__3__Impl
+	rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__Group_7__3__Impl
+rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_7_3()); }
-	(rule__UserTaskFlowElement__LabelAssignment_7_3)
-	{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_7_3()); }
+	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); }
+	(rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3)
+	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); }
 )
 ;
 finally {
@@ -4929,485 +4908,485 @@ finally {
 }
 
 
-rule__ManualTaskFlowElement__Group__0
+rule__ExternalServiceTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__0__Impl
-	rule__ManualTaskFlowElement__Group__1
+	rule__ExternalServiceTaskFlowElement__Group__0__Impl
+	rule__ExternalServiceTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__0__Impl
+rule__ExternalServiceTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
 	'FlowElement'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__1
+rule__ExternalServiceTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__1__Impl
-	rule__ManualTaskFlowElement__Group__2
+	rule__ExternalServiceTaskFlowElement__Group__1__Impl
+	rule__ExternalServiceTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__1__Impl
+rule__ExternalServiceTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__ManualTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__ExternalServiceTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__2
+rule__ExternalServiceTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__2__Impl
-	rule__ManualTaskFlowElement__Group__3
+	rule__ExternalServiceTaskFlowElement__Group__2__Impl
+	rule__ExternalServiceTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__2__Impl
+rule__ExternalServiceTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__3
+rule__ExternalServiceTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__3__Impl
-	rule__ManualTaskFlowElement__Group__4
+	rule__ExternalServiceTaskFlowElement__Group__3__Impl
+	rule__ExternalServiceTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__3__Impl
+rule__ExternalServiceTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); }
-	'ManualTask'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
+	'ServiceTask'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__4
+rule__ExternalServiceTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__4__Impl
-	rule__ManualTaskFlowElement__Group__5
+	rule__ExternalServiceTaskFlowElement__Group__4__Impl
+	rule__ExternalServiceTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__4__Impl
+rule__ExternalServiceTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); }
-	(rule__ManualTaskFlowElement__Group_4__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); }
+	'with'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__5
+rule__ExternalServiceTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__5__Impl
-	rule__ManualTaskFlowElement__Group__6
+	rule__ExternalServiceTaskFlowElement__Group__5__Impl
+	rule__ExternalServiceTaskFlowElement__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__5__Impl
+rule__ExternalServiceTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5()); }
-	(rule__ManualTaskFlowElement__Group_5__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); }
+	'external'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__6
+rule__ExternalServiceTaskFlowElement__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__6__Impl
-	rule__ManualTaskFlowElement__Group__7
+	rule__ExternalServiceTaskFlowElement__Group__6__Impl
+	rule__ExternalServiceTaskFlowElement__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__6__Impl
+rule__ExternalServiceTaskFlowElement__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6()); }
-	(rule__ManualTaskFlowElement__Group_6__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__7
+rule__ExternalServiceTaskFlowElement__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__7__Impl
-	rule__ManualTaskFlowElement__Group__8
+	rule__ExternalServiceTaskFlowElement__Group__7__Impl
+	rule__ExternalServiceTaskFlowElement__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__7__Impl
+rule__ExternalServiceTaskFlowElement__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_7()); }
-	(rule__ManualTaskFlowElement__Group_7__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_7()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); }
+	(rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7)
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__8
+rule__ExternalServiceTaskFlowElement__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group__8__Impl
+	rule__ExternalServiceTaskFlowElement__Group__8__Impl
+	rule__ExternalServiceTaskFlowElement__Group__9
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group__8__Impl
+rule__ExternalServiceTaskFlowElement__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); }
+	(rule__ExternalServiceTaskFlowElement__Group_8__0)?
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_4__0
+rule__ExternalServiceTaskFlowElement__Group__9
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__0__Impl
-	rule__ManualTaskFlowElement__Group_4__1
+	rule__ExternalServiceTaskFlowElement__Group__9__Impl
+	rule__ExternalServiceTaskFlowElement__Group__10
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__0__Impl
+rule__ExternalServiceTaskFlowElement__Group__9__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_4_0()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); }
+	(rule__ExternalServiceTaskFlowElement__Group_9__0)?
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__1
+rule__ExternalServiceTaskFlowElement__Group__10
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__1__Impl
-	rule__ManualTaskFlowElement__Group_4__2
+	rule__ExternalServiceTaskFlowElement__Group__10__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__1__Impl
+rule__ExternalServiceTaskFlowElement__Group__10__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_10()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_10()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__2
+
+rule__ExternalServiceTaskFlowElement__Group_8__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__2__Impl
-	rule__ManualTaskFlowElement__Group_4__3
+	rule__ExternalServiceTaskFlowElement__Group_8__0__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__2__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getInputsKeyword_4_2()); }
-	'inputs'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getInputsKeyword_4_2()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); }
+	'with'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__3
+rule__ExternalServiceTaskFlowElement__Group_8__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__3__Impl
-	rule__ManualTaskFlowElement__Group_4__4
+	rule__ExternalServiceTaskFlowElement__Group_8__1__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__3__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); }
+	'hardcoded'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__4
+rule__ExternalServiceTaskFlowElement__Group_8__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__4__Impl
-	rule__ManualTaskFlowElement__Group_4__5
+	rule__ExternalServiceTaskFlowElement__Group_8__2__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__4__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); }
+	'inputs'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__5
+rule__ExternalServiceTaskFlowElement__Group_8__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__5__Impl
-	rule__ManualTaskFlowElement__Group_4__6
+	rule__ExternalServiceTaskFlowElement__Group_8__3__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__5__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5()); }
-	(rule__ManualTaskFlowElement__Group_4_5__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__6
+rule__ExternalServiceTaskFlowElement__Group_8__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4__6__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__4__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4__6__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_4_5__0
+rule__ExternalServiceTaskFlowElement__Group_8__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4_5__0__Impl
-	rule__ManualTaskFlowElement__Group_4_5__1
+	rule__ExternalServiceTaskFlowElement__Group_8__5__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5__0__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
-	(rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); }
+	(rule__ExternalServiceTaskFlowElement__Group_8_5__0)?
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5__1
+rule__ExternalServiceTaskFlowElement__Group_8__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4_5__1__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5__1__Impl
+rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5_1()); }
-	(rule__ManualTaskFlowElement__Group_4_5_1__0)*
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5_1()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); }
 )
 ;
 finally {
@@ -5415,53 +5394,53 @@ finally {
 }
 
 
-rule__ManualTaskFlowElement__Group_4_5_1__0
+rule__ExternalServiceTaskFlowElement__Group_8_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4_5_1__0__Impl
-	rule__ManualTaskFlowElement__Group_4_5_1__1
+	rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5_1__0__Impl
+rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); }
+	(rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0)
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5_1__1
+rule__ExternalServiceTaskFlowElement__Group_8_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_4_5_1__1__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_4_5_1__1__Impl
+rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
-	(rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); }
+	(rule__ExternalServiceTaskFlowElement__Group_8_5_1__0)*
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); }
 )
 ;
 finally {
@@ -5469,161 +5448,161 @@ finally {
 }
 
 
-rule__ManualTaskFlowElement__Group_5__0
+rule__ExternalServiceTaskFlowElement__Group_8_5_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__0__Impl
-	rule__ManualTaskFlowElement__Group_5__1
+	rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl
+	rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__0__Impl
+rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_5_0()); }
-	'with'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_5_0()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__1
+rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__1__Impl
-	rule__ManualTaskFlowElement__Group_5__2
+	rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__1__Impl
+rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
-	'inputVariables'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); }
+	(rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1)
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__2
+
+rule__ExternalServiceTaskFlowElement__Group_9__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__2__Impl
-	rule__ManualTaskFlowElement__Group_5__3
+	rule__ExternalServiceTaskFlowElement__Group_9__0__Impl
+	rule__ExternalServiceTaskFlowElement__Group_9__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__2__Impl
+rule__ExternalServiceTaskFlowElement__Group_9__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_9_0()); }
+	'and'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_9_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__3
+rule__ExternalServiceTaskFlowElement__Group_9__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__3__Impl
-	rule__ManualTaskFlowElement__Group_5__4
+	rule__ExternalServiceTaskFlowElement__Group_9__1__Impl
+	rule__ExternalServiceTaskFlowElement__Group_9__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__3__Impl
+rule__ExternalServiceTaskFlowElement__Group_9__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_9_1()); }
+	'label'
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_9_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__4
+rule__ExternalServiceTaskFlowElement__Group_9__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__4__Impl
-	rule__ManualTaskFlowElement__Group_5__5
+	rule__ExternalServiceTaskFlowElement__Group_9__2__Impl
+	rule__ExternalServiceTaskFlowElement__Group_9__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__4__Impl
+rule__ExternalServiceTaskFlowElement__Group_9__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4()); }
-	(rule__ManualTaskFlowElement__Group_5_4__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__5
+rule__ExternalServiceTaskFlowElement__Group_9__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5__5__Impl
+	rule__ExternalServiceTaskFlowElement__Group_9__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5__5__Impl
+rule__ExternalServiceTaskFlowElement__Group_9__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
+	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_9_3()); }
+	(rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3)
+	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_9_3()); }
 )
 ;
 finally {
@@ -5631,917 +5610,917 @@ finally {
 }
 
 
-rule__ManualTaskFlowElement__Group_5_4__0
+rule__BusinessRuleTaskFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5_4__0__Impl
-	rule__ManualTaskFlowElement__Group_5_4__1
+	rule__BusinessRuleTaskFlowElement__Group__0__Impl
+	rule__BusinessRuleTaskFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4__0__Impl
+rule__BusinessRuleTaskFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
-	(rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4__1
+rule__BusinessRuleTaskFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5_4__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4__1__Impl
+rule__BusinessRuleTaskFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4_1()); }
-	(rule__ManualTaskFlowElement__Group_5_4_1__0)*
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4_1()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); }
+	(rule__BusinessRuleTaskFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_5_4_1__0
+rule__BusinessRuleTaskFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5_4_1__0__Impl
-	rule__ManualTaskFlowElement__Group_5_4_1__1
+	rule__BusinessRuleTaskFlowElement__Group__2__Impl
+	rule__BusinessRuleTaskFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4_1__0__Impl
+rule__BusinessRuleTaskFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4_1__1
+rule__BusinessRuleTaskFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_5_4_1__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group__3__Impl
+	rule__BusinessRuleTaskFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_5_4_1__1__Impl
+rule__BusinessRuleTaskFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
-	(rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); }
+	'BusinessRuleTask'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_6__0
+rule__BusinessRuleTaskFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__0__Impl
-	rule__ManualTaskFlowElement__Group_6__1
+	rule__BusinessRuleTaskFlowElement__Group__4__Impl
+	rule__BusinessRuleTaskFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__0__Impl
+rule__BusinessRuleTaskFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_6_0()); }
-	'with'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_6_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); }
+	(rule__BusinessRuleTaskFlowElement__Group_4__0)?
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__1
+rule__BusinessRuleTaskFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__1__Impl
-	rule__ManualTaskFlowElement__Group_6__2
+	rule__BusinessRuleTaskFlowElement__Group__5__Impl
+	rule__BusinessRuleTaskFlowElement__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__1__Impl
+rule__BusinessRuleTaskFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
-	'outputVariables'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); }
+	(rule__BusinessRuleTaskFlowElement__Group_5__0)?
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__2
+rule__BusinessRuleTaskFlowElement__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__2__Impl
-	rule__ManualTaskFlowElement__Group_6__3
+	rule__BusinessRuleTaskFlowElement__Group__6__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__2__Impl
+rule__BusinessRuleTaskFlowElement__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__3
+
+rule__BusinessRuleTaskFlowElement__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__3__Impl
-	rule__ManualTaskFlowElement__Group_6__4
+	rule__BusinessRuleTaskFlowElement__Group_4__0__Impl
+	rule__BusinessRuleTaskFlowElement__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__3__Impl
+rule__BusinessRuleTaskFlowElement__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); }
+	'with'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__4
+rule__BusinessRuleTaskFlowElement__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__4__Impl
-	rule__ManualTaskFlowElement__Group_6__5
+	rule__BusinessRuleTaskFlowElement__Group_4__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__4__Impl
+rule__BusinessRuleTaskFlowElement__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4()); }
-	(rule__ManualTaskFlowElement__Group_6_4__0)?
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); }
+	'resultVariable'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__5
+rule__BusinessRuleTaskFlowElement__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6__5__Impl
+	rule__BusinessRuleTaskFlowElement__Group_4__2__Impl
+	rule__BusinessRuleTaskFlowElement__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6__5__Impl
+rule__BusinessRuleTaskFlowElement__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_6_4__0
+rule__BusinessRuleTaskFlowElement__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6_4__0__Impl
-	rule__ManualTaskFlowElement__Group_6_4__1
+	rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4__0__Impl
+rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
-	(rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); }
+	(rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3)
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4__1
+
+rule__BusinessRuleTaskFlowElement__Group_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6_4__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group_5__0__Impl
+	rule__BusinessRuleTaskFlowElement__Group_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4__1__Impl
+rule__BusinessRuleTaskFlowElement__Group_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4_1()); }
-	(rule__ManualTaskFlowElement__Group_6_4_1__0)*
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4_1()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_5_0()); }
+	'and'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_6_4_1__0
+rule__BusinessRuleTaskFlowElement__Group_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6_4_1__0__Impl
-	rule__ManualTaskFlowElement__Group_6_4_1__1
+	rule__BusinessRuleTaskFlowElement__Group_5__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group_5__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4_1__0__Impl
+rule__BusinessRuleTaskFlowElement__Group_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_5_1()); }
+	'label'
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_5_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4_1__1
+rule__BusinessRuleTaskFlowElement__Group_5__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_6_4_1__1__Impl
+	rule__BusinessRuleTaskFlowElement__Group_5__2__Impl
+	rule__BusinessRuleTaskFlowElement__Group_5__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_6_4_1__1__Impl
+rule__BusinessRuleTaskFlowElement__Group_5__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
-	(rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ManualTaskFlowElement__Group_7__0
+rule__BusinessRuleTaskFlowElement__Group_5__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_7__0__Impl
-	rule__ManualTaskFlowElement__Group_7__1
+	rule__BusinessRuleTaskFlowElement__Group_5__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__0__Impl
+rule__BusinessRuleTaskFlowElement__Group_5__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_7_0()); }
-	'and'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_7_0()); }
+	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_5_3()); }
+	(rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3)
+	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_5_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__1
+
+rule__GatewayFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_7__1__Impl
-	rule__ManualTaskFlowElement__Group_7__2
+	rule__GatewayFlowElement__Group__0__Impl
+	rule__GatewayFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__1__Impl
+rule__GatewayFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_7_1()); }
-	'label'
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_7_1()); }
+	{ before(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__2
+rule__GatewayFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_7__2__Impl
-	rule__ManualTaskFlowElement__Group_7__3
+	rule__GatewayFlowElement__Group__1__Impl
+	rule__GatewayFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__2__Impl
+rule__GatewayFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ before(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); }
+	(rule__GatewayFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__3
+rule__GatewayFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ManualTaskFlowElement__Group_7__3__Impl
+	rule__GatewayFlowElement__Group__2__Impl
+	rule__GatewayFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__Group_7__3__Impl
+rule__GatewayFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_7_3()); }
-	(rule__ManualTaskFlowElement__LabelAssignment_7_3)
-	{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_7_3()); }
+	{ before(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group__0
+rule__GatewayFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__0__Impl
-	rule__ScriptTaskFlowElement__Group__1
+	rule__GatewayFlowElement__Group__3__Impl
+	rule__GatewayFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__0__Impl
+rule__GatewayFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); }
+	'Gateway'
+	{ after(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__1
+rule__GatewayFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__1__Impl
-	rule__ScriptTaskFlowElement__Group__2
+	rule__GatewayFlowElement__Group__4__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__1__Impl
+rule__GatewayFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__ScriptTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__2
+
+rule__SequenceFlowElement__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__2__Impl
-	rule__ScriptTaskFlowElement__Group__3
+	rule__SequenceFlowElement__Group__0__Impl
+	rule__SequenceFlowElement__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__2__Impl
+rule__SequenceFlowElement__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); }
+	'FlowElement'
+	{ after(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__3
+rule__SequenceFlowElement__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__3__Impl
-	rule__ScriptTaskFlowElement__Group__4
+	rule__SequenceFlowElement__Group__1__Impl
+	rule__SequenceFlowElement__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__3__Impl
+rule__SequenceFlowElement__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); }
-	'ScriptTask'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); }
+	(rule__SequenceFlowElement__NameAssignment_1)
+	{ after(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__4
+rule__SequenceFlowElement__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__4__Impl
-	rule__ScriptTaskFlowElement__Group__5
+	rule__SequenceFlowElement__Group__2__Impl
+	rule__SequenceFlowElement__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__4__Impl
+rule__SequenceFlowElement__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); }
-	(rule__ScriptTaskFlowElement__Group_4__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__5
+rule__SequenceFlowElement__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__5__Impl
-	rule__ScriptTaskFlowElement__Group__6
+	rule__SequenceFlowElement__Group__3__Impl
+	rule__SequenceFlowElement__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__5__Impl
+rule__SequenceFlowElement__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5()); }
-	(rule__ScriptTaskFlowElement__Group_5__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); }
+	'SequenceFlow'
+	{ after(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__6
+rule__SequenceFlowElement__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__6__Impl
-	rule__ScriptTaskFlowElement__Group__7
+	rule__SequenceFlowElement__Group__4__Impl
+	rule__SequenceFlowElement__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__6__Impl
+rule__SequenceFlowElement__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6()); }
-	(rule__ScriptTaskFlowElement__Group_6__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); }
+	(rule__SequenceFlowElement__Group_4__0)?
+	{ after(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__7
+rule__SequenceFlowElement__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__7__Impl
-	rule__ScriptTaskFlowElement__Group__8
+	rule__SequenceFlowElement__Group__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__7__Impl
+rule__SequenceFlowElement__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_7()); }
-	(rule__ScriptTaskFlowElement__Group_7__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_7()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__8
+
+rule__SequenceFlowElement__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group__8__Impl
+	rule__SequenceFlowElement__Group_4__0__Impl
+	rule__SequenceFlowElement__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group__8__Impl
+rule__SequenceFlowElement__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); }
+	'with'
+	{ after(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_4__0
+rule__SequenceFlowElement__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__0__Impl
-	rule__ScriptTaskFlowElement__Group_4__1
+	rule__SequenceFlowElement__Group_4__1__Impl
+	rule__SequenceFlowElement__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__0__Impl
+rule__SequenceFlowElement__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_4_0()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); }
+	'expression'
+	{ after(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__1
+rule__SequenceFlowElement__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__1__Impl
-	rule__ScriptTaskFlowElement__Group_4__2
+	rule__SequenceFlowElement__Group_4__2__Impl
+	rule__SequenceFlowElement__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__1__Impl
+rule__SequenceFlowElement__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedKeyword_4_1()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__2
+rule__SequenceFlowElement__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__2__Impl
-	rule__ScriptTaskFlowElement__Group_4__3
+	rule__SequenceFlowElement__Group_4__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__2__Impl
+rule__SequenceFlowElement__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputsKeyword_4_2()); }
-	'inputs'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputsKeyword_4_2()); }
+	{ before(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); }
+	(rule__SequenceFlowElement__ExpressionAssignment_4_3)
+	{ after(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__3
+
+rule__FlowElementReference__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__3__Impl
-	rule__ScriptTaskFlowElement__Group_4__4
+	rule__FlowElementReference__Group__0__Impl
+	rule__FlowElementReference__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__3__Impl
+rule__FlowElementReference__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); }
+	{ before(grammarAccess.getFlowElementReferenceAccess().getRefAssignment_0()); }
+	(rule__FlowElementReference__RefAssignment_0)
+	{ after(grammarAccess.getFlowElementReferenceAccess().getRefAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__4
+rule__FlowElementReference__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__4__Impl
-	rule__ScriptTaskFlowElement__Group_4__5
+	rule__FlowElementReference__Group__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__4__Impl
+rule__FlowElementReference__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); }
+	{ before(grammarAccess.getFlowElementReferenceAccess().getGroup_1()); }
+	(rule__FlowElementReference__Group_1__0)?
+	{ after(grammarAccess.getFlowElementReferenceAccess().getGroup_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__5
+
+rule__FlowElementReference__Group_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__5__Impl
-	rule__ScriptTaskFlowElement__Group_4__6
+	rule__FlowElementReference__Group_1__0__Impl
+	rule__FlowElementReference__Group_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__5__Impl
+rule__FlowElementReference__Group_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5()); }
-	(rule__ScriptTaskFlowElement__Group_4_5__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5()); }
+	{ before(grammarAccess.getFlowElementReferenceAccess().getASSOCIATIONTerminalRuleCall_1_0()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getFlowElementReferenceAccess().getASSOCIATIONTerminalRuleCall_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__6
+rule__FlowElementReference__Group_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4__6__Impl
+	rule__FlowElementReference__Group_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4__6__Impl
+rule__FlowElementReference__Group_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); }
+	{ before(grammarAccess.getFlowElementReferenceAccess().getFlagAssignment_1_1()); }
+	(rule__FlowElementReference__FlagAssignment_1_1)
+	{ after(grammarAccess.getFlowElementReferenceAccess().getFlagAssignment_1_1()); }
 )
 ;
 finally {
@@ -6549,323 +6528,323 @@ finally {
 }
 
 
-rule__ScriptTaskFlowElement__Group_4_5__0
+rule__ExternalTopic__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4_5__0__Impl
-	rule__ScriptTaskFlowElement__Group_4_5__1
+	rule__ExternalTopic__Group__0__Impl
+	rule__ExternalTopic__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5__0__Impl
+rule__ExternalTopic__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
-	(rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); }
+	{ before(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); }
+	'ExternalTopic'
+	{ after(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5__1
+rule__ExternalTopic__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4_5__1__Impl
+	rule__ExternalTopic__Group__1__Impl
+	rule__ExternalTopic__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5__1__Impl
+rule__ExternalTopic__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5_1()); }
-	(rule__ScriptTaskFlowElement__Group_4_5_1__0)*
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5_1()); }
+	{ before(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); }
+	(rule__ExternalTopic__NameAssignment_1)
+	{ after(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_4_5_1__0
+rule__ExternalTopic__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl
-	rule__ScriptTaskFlowElement__Group_4_5_1__1
+	rule__ExternalTopic__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl
+rule__ExternalTopic__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); }
+	{ before(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5_1__1
+
+rule__StringVariable__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl
+	rule__StringVariable__Group__0__Impl
+	rule__StringVariable__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl
+rule__StringVariable__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
-	(rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); }
+	{ before(grammarAccess.getStringVariableAccess().getStringKeyword_0()); }
+	'String'
+	{ after(grammarAccess.getStringVariableAccess().getStringKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_5__0
+rule__StringVariable__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__0__Impl
-	rule__ScriptTaskFlowElement__Group_5__1
+	rule__StringVariable__Group__1__Impl
+	rule__StringVariable__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__0__Impl
+rule__StringVariable__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_5_0()); }
-	'with'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_5_0()); }
+	{ before(grammarAccess.getStringVariableAccess().getNameAssignment_1()); }
+	(rule__StringVariable__NameAssignment_1)
+	{ after(grammarAccess.getStringVariableAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__1
+rule__StringVariable__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__1__Impl
-	rule__ScriptTaskFlowElement__Group_5__2
+	rule__StringVariable__Group__2__Impl
+	rule__StringVariable__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__1__Impl
+rule__StringVariable__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
-	'inputVariables'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesKeyword_5_1()); }
+	{ before(grammarAccess.getStringVariableAccess().getWithKeyword_2()); }
+	'with'
+	{ after(grammarAccess.getStringVariableAccess().getWithKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__2
+rule__StringVariable__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__2__Impl
-	rule__ScriptTaskFlowElement__Group_5__3
+	rule__StringVariable__Group__3__Impl
+	rule__StringVariable__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__2__Impl
+rule__StringVariable__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); }
+	{ before(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); }
+	'proposals'
+	{ after(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__3
+rule__StringVariable__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__3__Impl
-	rule__ScriptTaskFlowElement__Group_5__4
+	rule__StringVariable__Group__4__Impl
+	rule__StringVariable__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__3__Impl
+rule__StringVariable__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); }
+	{ before(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__4
+rule__StringVariable__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__4__Impl
-	rule__ScriptTaskFlowElement__Group_5__5
+	rule__StringVariable__Group__5__Impl
+	rule__StringVariable__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__4__Impl
+rule__StringVariable__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4()); }
-	(rule__ScriptTaskFlowElement__Group_5_4__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4()); }
+	{ before(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__5
+rule__StringVariable__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5__5__Impl
+	rule__StringVariable__Group__6__Impl
+	rule__StringVariable__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5__5__Impl
+rule__StringVariable__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); }
+	{ before(grammarAccess.getStringVariableAccess().getGroup_6()); }
+	(rule__StringVariable__Group_6__0)?
+	{ after(grammarAccess.getStringVariableAccess().getGroup_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_5_4__0
+rule__StringVariable__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5_4__0__Impl
-	rule__ScriptTaskFlowElement__Group_5_4__1
+	rule__StringVariable__Group__7__Impl
+	rule__StringVariable__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4__0__Impl
+rule__StringVariable__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
-	(rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); }
+	{ before(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4__1
+rule__StringVariable__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5_4__1__Impl
+	rule__StringVariable__Group__8__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4__1__Impl
+rule__StringVariable__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4_1()); }
-	(rule__ScriptTaskFlowElement__Group_5_4_1__0)*
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4_1()); }
+	{ before(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 )
 ;
 finally {
@@ -6873,53 +6852,53 @@ finally {
 }
 
 
-rule__ScriptTaskFlowElement__Group_5_4_1__0
+rule__StringVariable__Group_6__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl
-	rule__ScriptTaskFlowElement__Group_5_4_1__1
+	rule__StringVariable__Group_6__0__Impl
+	rule__StringVariable__Group_6__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl
+rule__StringVariable__Group_6__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); }
+	{ before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); }
+	(rule__StringVariable__ProposalsAssignment_6_0)
+	{ after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4_1__1
+rule__StringVariable__Group_6__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl
+	rule__StringVariable__Group_6__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl
+rule__StringVariable__Group_6__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
-	(rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); }
+	{ before(grammarAccess.getStringVariableAccess().getGroup_6_1()); }
+	(rule__StringVariable__Group_6_1__0)*
+	{ after(grammarAccess.getStringVariableAccess().getGroup_6_1()); }
 )
 ;
 finally {
@@ -6927,647 +6906,647 @@ finally {
 }
 
 
-rule__ScriptTaskFlowElement__Group_6__0
+rule__StringVariable__Group_6_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__0__Impl
-	rule__ScriptTaskFlowElement__Group_6__1
+	rule__StringVariable__Group_6_1__0__Impl
+	rule__StringVariable__Group_6_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__0__Impl
+rule__StringVariable__Group_6_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_6_0()); }
-	'with'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_6_0()); }
+	{ before(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__1
+rule__StringVariable__Group_6_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__1__Impl
-	rule__ScriptTaskFlowElement__Group_6__2
+	rule__StringVariable__Group_6_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__1__Impl
+rule__StringVariable__Group_6_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
-	'outputVariables'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); }
+	{ before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); }
+	(rule__StringVariable__ProposalsAssignment_6_1_1)
+	{ after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__2
+
+rule__IntVariable__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__2__Impl
-	rule__ScriptTaskFlowElement__Group_6__3
+	rule__IntVariable__Group__0__Impl
+	rule__IntVariable__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__2__Impl
+rule__IntVariable__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
+	{ before(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); }
+	'Integer'
+	{ after(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__3
+rule__IntVariable__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__3__Impl
-	rule__ScriptTaskFlowElement__Group_6__4
+	rule__IntVariable__Group__1__Impl
+	rule__IntVariable__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__3__Impl
+rule__IntVariable__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
+	{ before(grammarAccess.getIntVariableAccess().getNameAssignment_1()); }
+	(rule__IntVariable__NameAssignment_1)
+	{ after(grammarAccess.getIntVariableAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__4
+rule__IntVariable__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__4__Impl
-	rule__ScriptTaskFlowElement__Group_6__5
+	rule__IntVariable__Group__2__Impl
+	rule__IntVariable__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__4__Impl
+rule__IntVariable__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4()); }
-	(rule__ScriptTaskFlowElement__Group_6_4__0)?
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4()); }
+	{ before(grammarAccess.getIntVariableAccess().getWithKeyword_2()); }
+	'with'
+	{ after(grammarAccess.getIntVariableAccess().getWithKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__5
+rule__IntVariable__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6__5__Impl
+	rule__IntVariable__Group__3__Impl
+	rule__IntVariable__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6__5__Impl
+rule__IntVariable__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
+	{ before(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); }
+	'proposals'
+	{ after(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_6_4__0
+rule__IntVariable__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6_4__0__Impl
-	rule__ScriptTaskFlowElement__Group_6_4__1
+	rule__IntVariable__Group__4__Impl
+	rule__IntVariable__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4__0__Impl
+rule__IntVariable__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
-	(rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); }
+	{ before(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4__1
+rule__IntVariable__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6_4__1__Impl
+	rule__IntVariable__Group__5__Impl
+	rule__IntVariable__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4__1__Impl
+rule__IntVariable__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4_1()); }
-	(rule__ScriptTaskFlowElement__Group_6_4_1__0)*
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4_1()); }
+	{ before(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_6_4_1__0
+rule__IntVariable__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl
-	rule__ScriptTaskFlowElement__Group_6_4_1__1
+	rule__IntVariable__Group__6__Impl
+	rule__IntVariable__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl
+rule__IntVariable__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
+	{ before(grammarAccess.getIntVariableAccess().getGroup_6()); }
+	(rule__IntVariable__Group_6__0)?
+	{ after(grammarAccess.getIntVariableAccess().getGroup_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4_1__1
+rule__IntVariable__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl
+	rule__IntVariable__Group__7__Impl
+	rule__IntVariable__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl
+rule__IntVariable__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
-	(rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); }
+	{ before(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ScriptTaskFlowElement__Group_7__0
+rule__IntVariable__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_7__0__Impl
-	rule__ScriptTaskFlowElement__Group_7__1
+	rule__IntVariable__Group__8__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__0__Impl
+rule__IntVariable__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_7_0()); }
-	'and'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_7_0()); }
+	{ before(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__1
+
+rule__IntVariable__Group_6__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_7__1__Impl
-	rule__ScriptTaskFlowElement__Group_7__2
+	rule__IntVariable__Group_6__0__Impl
+	rule__IntVariable__Group_6__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__1__Impl
+rule__IntVariable__Group_6__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_7_1()); }
-	'label'
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_7_1()); }
+	{ before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); }
+	(rule__IntVariable__ProposalsAssignment_6_0)
+	{ after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__2
+rule__IntVariable__Group_6__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_7__2__Impl
-	rule__ScriptTaskFlowElement__Group_7__3
+	rule__IntVariable__Group_6__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__2__Impl
+rule__IntVariable__Group_6__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ before(grammarAccess.getIntVariableAccess().getGroup_6_1()); }
+	(rule__IntVariable__Group_6_1__0)*
+	{ after(grammarAccess.getIntVariableAccess().getGroup_6_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__3
+
+rule__IntVariable__Group_6_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ScriptTaskFlowElement__Group_7__3__Impl
+	rule__IntVariable__Group_6_1__0__Impl
+	rule__IntVariable__Group_6_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__Group_7__3__Impl
+rule__IntVariable__Group_6_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_7_3()); }
-	(rule__ScriptTaskFlowElement__LabelAssignment_7_3)
-	{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_7_3()); }
+	{ before(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__DelegateServiceTaskFlowElement__Group__0
+rule__IntVariable__Group_6_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__0__Impl
-	rule__DelegateServiceTaskFlowElement__Group__1
+	rule__IntVariable__Group_6_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__0__Impl
+rule__IntVariable__Group_6_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); }
+	(rule__IntVariable__ProposalsAssignment_6_1_1)
+	{ after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__1
+
+rule__BooleanVariable__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__1__Impl
-	rule__DelegateServiceTaskFlowElement__Group__2
+	rule__BooleanVariable__Group__0__Impl
+	rule__BooleanVariable__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__1__Impl
+rule__BooleanVariable__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__DelegateServiceTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); }
+	'Boolean'
+	{ after(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__2
+rule__BooleanVariable__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__2__Impl
-	rule__DelegateServiceTaskFlowElement__Group__3
+	rule__BooleanVariable__Group__1__Impl
+	rule__BooleanVariable__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__2__Impl
+rule__BooleanVariable__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); }
+	(rule__BooleanVariable__NameAssignment_1)
+	{ after(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__3
+rule__BooleanVariable__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__3__Impl
-	rule__DelegateServiceTaskFlowElement__Group__4
+	rule__BooleanVariable__Group__2__Impl
+	rule__BooleanVariable__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__3__Impl
+rule__BooleanVariable__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
-	'ServiceTask'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); }
+	'with'
+	{ after(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__4
+rule__BooleanVariable__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__4__Impl
-	rule__DelegateServiceTaskFlowElement__Group__5
+	rule__BooleanVariable__Group__3__Impl
+	rule__BooleanVariable__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__4__Impl
+rule__BooleanVariable__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); }
-	'with'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); }
+	'proposals'
+	{ after(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__5
+rule__BooleanVariable__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__5__Impl
-	rule__DelegateServiceTaskFlowElement__Group__6
+	rule__BooleanVariable__Group__4__Impl
+	rule__BooleanVariable__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__5__Impl
+rule__BooleanVariable__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); }
-	'delegate'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__6
+rule__BooleanVariable__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__6__Impl
-	rule__DelegateServiceTaskFlowElement__Group__7
+	rule__BooleanVariable__Group__5__Impl
+	rule__BooleanVariable__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__6__Impl
+rule__BooleanVariable__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__7
+rule__BooleanVariable__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__7__Impl
-	rule__DelegateServiceTaskFlowElement__Group__8
+	rule__BooleanVariable__Group__6__Impl
+	rule__BooleanVariable__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__7__Impl
+rule__BooleanVariable__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); }
-	(rule__DelegateServiceTaskFlowElement__DelegateAssignment_7)
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getGroup_6()); }
+	(rule__BooleanVariable__Group_6__0)?
+	{ after(grammarAccess.getBooleanVariableAccess().getGroup_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__8
+rule__BooleanVariable__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__8__Impl
-	rule__DelegateServiceTaskFlowElement__Group__9
+	rule__BooleanVariable__Group__7__Impl
+	rule__BooleanVariable__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__8__Impl
+rule__BooleanVariable__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); }
-	(rule__DelegateServiceTaskFlowElement__Group_8__0)?
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__9
+rule__BooleanVariable__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group__9__Impl
+	rule__BooleanVariable__Group__8__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group__9__Impl
+rule__BooleanVariable__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
+	{ after(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 )
 ;
 finally {
@@ -7575,107 +7554,107 @@ finally {
 }
 
 
-rule__DelegateServiceTaskFlowElement__Group_8__0
+rule__BooleanVariable__Group_6__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group_8__0__Impl
-	rule__DelegateServiceTaskFlowElement__Group_8__1
+	rule__BooleanVariable__Group_6__0__Impl
+	rule__BooleanVariable__Group_6__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__0__Impl
+rule__BooleanVariable__Group_6__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); }
-	'and'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); }
+	(rule__BooleanVariable__ProposalsAssignment_6_0)
+	{ after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__1
+rule__BooleanVariable__Group_6__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group_8__1__Impl
-	rule__DelegateServiceTaskFlowElement__Group_8__2
+	rule__BooleanVariable__Group_6__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__1__Impl
+rule__BooleanVariable__Group_6__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); }
-	'label'
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); }
+	(rule__BooleanVariable__Group_6_1__0)*
+	{ after(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__2
+
+rule__BooleanVariable__Group_6_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group_8__2__Impl
-	rule__DelegateServiceTaskFlowElement__Group_8__3
+	rule__BooleanVariable__Group_6_1__0__Impl
+	rule__BooleanVariable__Group_6_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__2__Impl
+rule__BooleanVariable__Group_6_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__3
+rule__BooleanVariable__Group_6_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
+	rule__BooleanVariable__Group_6_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
+rule__BooleanVariable__Group_6_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); }
-	(rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3)
-	{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); }
+	{ before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); }
+	(rule__BooleanVariable__ProposalsAssignment_6_1_1)
+	{ after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); }
 )
 ;
 finally {
@@ -7683,539 +7662,539 @@ finally {
 }
 
 
-rule__ExternalServiceTaskFlowElement__Group__0
+rule__Loop__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group__1
+	rule__Loop__Group__0__Impl
+	rule__Loop__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__0__Impl
+rule__Loop__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getLoopAccess().getLoopKeyword_0()); }
+	'Loop'
+	{ after(grammarAccess.getLoopAccess().getLoopKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__1
+rule__Loop__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__1__Impl
-	rule__ExternalServiceTaskFlowElement__Group__2
+	rule__Loop__Group__1__Impl
+	rule__Loop__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__1__Impl
+rule__Loop__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__ExternalServiceTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getLoopAccess().getNameAssignment_1()); }
+	(rule__Loop__NameAssignment_1)
+	{ after(grammarAccess.getLoopAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__2
+rule__Loop__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__2__Impl
-	rule__ExternalServiceTaskFlowElement__Group__3
+	rule__Loop__Group__2__Impl
+	rule__Loop__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__2__Impl
+rule__Loop__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getLoopAccess().getStartsKeyword_2()); }
+	'starts'
+	{ after(grammarAccess.getLoopAccess().getStartsKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__3
+rule__Loop__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__3__Impl
-	rule__ExternalServiceTaskFlowElement__Group__4
+	rule__Loop__Group__3__Impl
+	rule__Loop__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__3__Impl
+rule__Loop__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
-	'ServiceTask'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); }
+	{ before(grammarAccess.getLoopAccess().getWithKeyword_3()); }
+	'with'
+	{ after(grammarAccess.getLoopAccess().getWithKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__4
+rule__Loop__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__4__Impl
-	rule__ExternalServiceTaskFlowElement__Group__5
+	rule__Loop__Group__4__Impl
+	rule__Loop__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__4__Impl
+rule__Loop__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); }
-	'with'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); }
+	{ before(grammarAccess.getLoopAccess().getStartAssignment_4()); }
+	(rule__Loop__StartAssignment_4)
+	{ after(grammarAccess.getLoopAccess().getStartAssignment_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__5
+rule__Loop__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__5__Impl
-	rule__ExternalServiceTaskFlowElement__Group__6
+	rule__Loop__Group__5__Impl
+	rule__Loop__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__5__Impl
+rule__Loop__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); }
-	'external'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); }
-)
-;
+	{ before(grammarAccess.getLoopAccess().getFollowsKeyword_5()); }
+	'follows'
+	{ after(grammarAccess.getLoopAccess().getFollowsKeyword_5()); }
+)
+;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__6
+rule__Loop__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__6__Impl
-	rule__ExternalServiceTaskFlowElement__Group__7
+	rule__Loop__Group__6__Impl
+	rule__Loop__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__6__Impl
+rule__Loop__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); }
+	{ before(grammarAccess.getLoopAccess().getByKeyword_6()); }
+	'by'
+	{ after(grammarAccess.getLoopAccess().getByKeyword_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__7
+rule__Loop__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__7__Impl
-	rule__ExternalServiceTaskFlowElement__Group__8
+	rule__Loop__Group__7__Impl
+	rule__Loop__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__7__Impl
+rule__Loop__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); }
-	(rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); }
+	{ before(grammarAccess.getLoopAccess().getFollowerAssignment_7()); }
+	(rule__Loop__FollowerAssignment_7)
+	{ after(grammarAccess.getLoopAccess().getFollowerAssignment_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__8
+rule__Loop__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__8__Impl
-	rule__ExternalServiceTaskFlowElement__Group__9
+	rule__Loop__Group__8__Impl
+	rule__Loop__Group__9
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__8__Impl
+rule__Loop__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); }
-	(rule__ExternalServiceTaskFlowElement__Group_8__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); }
+	{ before(grammarAccess.getLoopAccess().getEndsKeyword_8()); }
+	'ends'
+	{ after(grammarAccess.getLoopAccess().getEndsKeyword_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__9
+rule__Loop__Group__9
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__9__Impl
-	rule__ExternalServiceTaskFlowElement__Group__10
+	rule__Loop__Group__9__Impl
+	rule__Loop__Group__10
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__9__Impl
+rule__Loop__Group__9__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); }
-	(rule__ExternalServiceTaskFlowElement__Group_9__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); }
+	{ before(grammarAccess.getLoopAccess().getWithKeyword_9()); }
+	'with'
+	{ after(grammarAccess.getLoopAccess().getWithKeyword_9()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__10
+rule__Loop__Group__10
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__10__Impl
-	rule__ExternalServiceTaskFlowElement__Group__11
+	rule__Loop__Group__10__Impl
+	rule__Loop__Group__11
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__10__Impl
+rule__Loop__Group__10__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10()); }
-	(rule__ExternalServiceTaskFlowElement__Group_10__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10()); }
+	{ before(grammarAccess.getLoopAccess().getEndAssignment_10()); }
+	(rule__Loop__EndAssignment_10)
+	{ after(grammarAccess.getLoopAccess().getEndAssignment_10()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__11
+rule__Loop__Group__11
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__11__Impl
-	rule__ExternalServiceTaskFlowElement__Group__12
+	rule__Loop__Group__11__Impl
+	rule__Loop__Group__12
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__11__Impl
+rule__Loop__Group__11__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_11()); }
-	(rule__ExternalServiceTaskFlowElement__Group_11__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_11()); }
+	{ before(grammarAccess.getLoopAccess().getHasKeyword_11()); }
+	'has'
+	{ after(grammarAccess.getLoopAccess().getHasKeyword_11()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__12
+rule__Loop__Group__12
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group__12__Impl
+	rule__Loop__Group__12__Impl
+	rule__Loop__Group__13
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group__12__Impl
+rule__Loop__Group__12__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
+	{ before(grammarAccess.getLoopAccess().getComplexityKeyword_12()); }
+	'complexity'
+	{ after(grammarAccess.getLoopAccess().getComplexityKeyword_12()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_8__0
+rule__Loop__Group__13
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__1
+	rule__Loop__Group__13__Impl
+	rule__Loop__Group__14
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__0__Impl
+rule__Loop__Group__13__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); }
-	'with'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); }
+	{ before(grammarAccess.getLoopAccess().getComplexityAssignment_13()); }
+	(rule__Loop__ComplexityAssignment_13)
+	{ after(grammarAccess.getLoopAccess().getComplexityAssignment_13()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__1
+rule__Loop__Group__14
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__1__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__2
+	rule__Loop__Group__14__Impl
+	rule__Loop__Group__15
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__1__Impl
+rule__Loop__Group__14__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); }
+	{ before(grammarAccess.getLoopAccess().getPassedKeyword_14()); }
+	'passed'
+	{ after(grammarAccess.getLoopAccess().getPassedKeyword_14()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__2
+rule__Loop__Group__15
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__2__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__3
+	rule__Loop__Group__15__Impl
+	rule__Loop__Group__16
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__2__Impl
+rule__Loop__Group__15__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); }
-	'inputs'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); }
+	{ before(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__3
+rule__Loop__Group__16
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__3__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__4
+	rule__Loop__Group__16__Impl
+	rule__Loop__Group__17
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__3__Impl
+rule__Loop__Group__16__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); }
+	{ before(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__4
+rule__Loop__Group__17
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__4__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__5
+	rule__Loop__Group__17__Impl
+	rule__Loop__Group__18
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__4__Impl
+rule__Loop__Group__17__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); }
+	{ before(grammarAccess.getLoopAccess().getGroup_17()); }
+	(rule__Loop__Group_17__0)?
+	{ after(grammarAccess.getLoopAccess().getGroup_17()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__5
+rule__Loop__Group__18
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__5__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8__6
+	rule__Loop__Group__18__Impl
+	rule__Loop__Group__19
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__5__Impl
+rule__Loop__Group__18__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); }
-	(rule__ExternalServiceTaskFlowElement__Group_8_5__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); }
+	{ before(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__6
+rule__Loop__Group__19
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
+	rule__Loop__Group__19__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
+rule__Loop__Group__19__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); }
+	{ before(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); }
 )
 ;
 finally {
@@ -8223,53 +8202,53 @@ finally {
 }
 
 
-rule__ExternalServiceTaskFlowElement__Group_8_5__0
+rule__Loop__Group_17__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8_5__1
+	rule__Loop__Group_17__0__Impl
+	rule__Loop__Group_17__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl
+rule__Loop__Group_17__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); }
-	(rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); }
+	{ before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); }
+	(rule__Loop__FrequenciesAssignment_17_0)
+	{ after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5__1
+rule__Loop__Group_17__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
+	rule__Loop__Group_17__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
+rule__Loop__Group_17__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); }
-	(rule__ExternalServiceTaskFlowElement__Group_8_5_1__0)*
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); }
+	{ before(grammarAccess.getLoopAccess().getGroup_17_1()); }
+	(rule__Loop__Group_17_1__0)*
+	{ after(grammarAccess.getLoopAccess().getGroup_17_1()); }
 )
 ;
 finally {
@@ -8277,53 +8256,53 @@ finally {
 }
 
 
-rule__ExternalServiceTaskFlowElement__Group_8_5_1__0
+rule__Loop__Group_17_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
+	rule__Loop__Group_17_1__0__Impl
+	rule__Loop__Group_17_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl
+rule__Loop__Group_17_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); }
+	{ before(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); }
 	RULE_SEPARATOR
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); }
+	{ after(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
+rule__Loop__Group_17_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
+	rule__Loop__Group_17_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
+rule__Loop__Group_17_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); }
-	(rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); }
+	{ before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); }
+	(rule__Loop__FrequenciesAssignment_17_1_1)
+	{ after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); }
 )
 ;
 finally {
@@ -8331,1214 +8310,1214 @@ finally {
 }
 
 
-rule__ExternalServiceTaskFlowElement__Group_9__0
+rule__Flow__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9__1
+	rule__Flow__Group__0__Impl
+	rule__Flow__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__0__Impl
+rule__Flow__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_9_0()); }
-	'with'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_9_0()); }
+	{ before(grammarAccess.getFlowAccess().getFlowKeyword_0()); }
+	'Flow'
+	{ after(grammarAccess.getFlowAccess().getFlowKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__1
+rule__Flow__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__1__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9__2
+	rule__Flow__Group__1__Impl
+	rule__Flow__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__1__Impl
+rule__Flow__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesKeyword_9_1()); }
-	'inputVariables'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesKeyword_9_1()); }
-)
-;
+	{ before(grammarAccess.getFlowAccess().getNameAssignment_1()); }
+	(rule__Flow__NameAssignment_1)
+	{ after(grammarAccess.getFlowAccess().getNameAssignment_1()); }
+)
+;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__2
+rule__Flow__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__2__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9__3
+	rule__Flow__Group__2__Impl
+	rule__Flow__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__2__Impl
+rule__Flow__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); }
+	{ before(grammarAccess.getFlowAccess().getForKeyword_2()); }
+	'for'
+	{ after(grammarAccess.getFlowAccess().getForKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__3
+rule__Flow__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__3__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9__4
+	rule__Flow__Group__3__Impl
+	rule__Flow__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__3__Impl
+rule__Flow__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_9_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_9_3()); }
+	{ before(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); }
+	(rule__Flow__BpmnReferenceAssignment_3)
+	{ after(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__4
+rule__Flow__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__4__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9__5
+	rule__Flow__Group__4__Impl
+	rule__Flow__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__4__Impl
+rule__Flow__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4()); }
-	(rule__ExternalServiceTaskFlowElement__Group_9_4__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_4()); }
+	(rule__Flow__Group_4__0)?
+	{ after(grammarAccess.getFlowAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__5
+rule__Flow__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9__5__Impl
+	rule__Flow__Group__5__Impl
+	rule__Flow__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9__5__Impl
+rule__Flow__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_9_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_9_5()); }
+	{ before(grammarAccess.getFlowAccess().getWithKeyword_5()); }
+	'with'
+	{ after(grammarAccess.getFlowAccess().getWithKeyword_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_9_4__0
+rule__Flow__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9_4__1
+	rule__Flow__Group__6__Impl
+	rule__Flow__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl
+rule__Flow__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_0()); }
-	(rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_0()); }
+	{ before(grammarAccess.getFlowAccess().getElementsKeyword_6()); }
+	'elements'
+	{ after(grammarAccess.getFlowAccess().getElementsKeyword_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4__1
+rule__Flow__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl
+	rule__Flow__Group__7__Impl
+	rule__Flow__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl
+rule__Flow__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4_1()); }
-	(rule__ExternalServiceTaskFlowElement__Group_9_4_1__0)*
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4_1()); }
+	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_9_4_1__0
+rule__Flow__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_9_4_1__1
+	rule__Flow__Group__8__Impl
+	rule__Flow__Group__9
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl
+rule__Flow__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_9_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_9_4_1_0()); }
+	{ before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4_1__1
+rule__Flow__Group__9
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl
+	rule__Flow__Group__9__Impl
+	rule__Flow__Group__10
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl
+rule__Flow__Group__9__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_1_1()); }
-	(rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_1_1()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_9()); }
+	(rule__Flow__Group_9__0)?
+	{ after(grammarAccess.getFlowAccess().getGroup_9()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_10__0
+rule__Flow__Group__10
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10__1
+	rule__Flow__Group__10__Impl
+	rule__Flow__Group__11
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__0__Impl
+rule__Flow__Group__10__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_10_0()); }
-	'with'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_10_0()); }
+	{ before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__1
+rule__Flow__Group__11
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__1__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10__2
+	rule__Flow__Group__11__Impl
+	rule__Flow__Group__12
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__1__Impl
+rule__Flow__Group__11__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesKeyword_10_1()); }
-	'outputVariables'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesKeyword_10_1()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_11()); }
+	(rule__Flow__Group_11__0)?
+	{ after(grammarAccess.getFlowAccess().getGroup_11()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__2
+rule__Flow__Group__12
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__2__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10__3
+	rule__Flow__Group__12__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__2__Impl
+rule__Flow__Group__12__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_10_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_10_2()); }
+	{ before(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__3
+
+rule__Flow__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__3__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10__4
+	rule__Flow__Group_4__0__Impl
+	rule__Flow__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__3__Impl
+rule__Flow__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_10_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_10_3()); }
+	{ before(grammarAccess.getFlowAccess().getWithKeyword_4_0()); }
+	'with'
+	{ after(grammarAccess.getFlowAccess().getWithKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__4
+rule__Flow__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__4__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10__5
+	rule__Flow__Group_4__1__Impl
+	rule__Flow__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__4__Impl
+rule__Flow__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4()); }
-	(rule__ExternalServiceTaskFlowElement__Group_10_4__0)?
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4()); }
+	{ before(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); }
+	'flag'
+	{ after(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__5
+rule__Flow__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10__5__Impl
+	rule__Flow__Group_4__2__Impl
+	rule__Flow__Group_4__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10__5__Impl
+rule__Flow__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_10_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_10_5()); }
+	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_10_4__0
+rule__Flow__Group_4__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10_4__1
+	rule__Flow__Group_4__3__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl
+rule__Flow__Group_4__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_0()); }
-	(rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_0()); }
+	{ before(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); }
+	(rule__Flow__FlagAssignment_4_3)
+	{ after(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4__1
+
+rule__Flow__Group_9__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl
+	rule__Flow__Group_9__0__Impl
+	rule__Flow__Group_9__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl
+rule__Flow__Group_9__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4_1()); }
-	(rule__ExternalServiceTaskFlowElement__Group_10_4_1__0)*
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4_1()); }
+	{ before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); }
+	(rule__Flow__InclElementsAssignment_9_0)
+	{ after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_10_4_1__0
+rule__Flow__Group_9__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_10_4_1__1
+	rule__Flow__Group_9__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl
+rule__Flow__Group_9__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_10_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_10_4_1_0()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_9_1()); }
+	(rule__Flow__Group_9_1__0)*
+	{ after(grammarAccess.getFlowAccess().getGroup_9_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4_1__1
+
+rule__Flow__Group_9_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl
+	rule__Flow__Group_9_1__0__Impl
+	rule__Flow__Group_9_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl
+rule__Flow__Group_9_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_1_1()); }
-	(rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_1_1()); }
+	{ before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__ExternalServiceTaskFlowElement__Group_11__0
+rule__Flow__Group_9_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_11__0__Impl
-	rule__ExternalServiceTaskFlowElement__Group_11__1
+	rule__Flow__Group_9_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__0__Impl
+rule__Flow__Group_9_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_11_0()); }
-	'and'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_11_0()); }
+	{ before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); }
+	(rule__Flow__InclElementsAssignment_9_1_1)
+	{ after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__1
+
+rule__Flow__Group_11__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_11__1__Impl
-	rule__ExternalServiceTaskFlowElement__Group_11__2
+	rule__Flow__Group_11__0__Impl
+	rule__Flow__Group_11__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__1__Impl
+rule__Flow__Group_11__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_11_1()); }
-	'label'
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_11_1()); }
+	{ before(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); }
+	'without'
+	{ after(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__2
+rule__Flow__Group_11__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_11__2__Impl
-	rule__ExternalServiceTaskFlowElement__Group_11__3
+	rule__Flow__Group_11__1__Impl
+	rule__Flow__Group_11__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__2__Impl
+rule__Flow__Group_11__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
+	{ before(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); }
+	'elements'
+	{ after(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__3
+rule__Flow__Group_11__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalServiceTaskFlowElement__Group_11__3__Impl
+	rule__Flow__Group_11__2__Impl
+	rule__Flow__Group_11__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__Group_11__3__Impl
+rule__Flow__Group_11__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_11_3()); }
-	(rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3)
-	{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_11_3()); }
+	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__BusinessRuleTaskFlowElement__Group__0
+rule__Flow__Group_11__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group__1
+	rule__Flow__Group_11__3__Impl
+	rule__Flow__Group_11__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__0__Impl
+rule__Flow__Group_11__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__1
+rule__Flow__Group_11__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group__2
+	rule__Flow__Group_11__4__Impl
+	rule__Flow__Group_11__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__1__Impl
+rule__Flow__Group_11__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); }
-	(rule__BusinessRuleTaskFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_11_4()); }
+	(rule__Flow__Group_11_4__0)?
+	{ after(grammarAccess.getFlowAccess().getGroup_11_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__2
+rule__Flow__Group_11__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group__3
+	rule__Flow__Group_11__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__2__Impl
+rule__Flow__Group_11__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__3
+
+rule__Flow__Group_11_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__3__Impl
-	rule__BusinessRuleTaskFlowElement__Group__4
+	rule__Flow__Group_11_4__0__Impl
+	rule__Flow__Group_11_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__3__Impl
+rule__Flow__Group_11_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); }
-	'BusinessRuleTask'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); }
+	{ before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); }
+	(rule__Flow__ExclElementsAssignment_11_4_0)
+	{ after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__4
+rule__Flow__Group_11_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__4__Impl
-	rule__BusinessRuleTaskFlowElement__Group__5
+	rule__Flow__Group_11_4__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__4__Impl
+rule__Flow__Group_11_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); }
-	(rule__BusinessRuleTaskFlowElement__Group_4__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); }
+	{ before(grammarAccess.getFlowAccess().getGroup_11_4_1()); }
+	(rule__Flow__Group_11_4_1__0)*
+	{ after(grammarAccess.getFlowAccess().getGroup_11_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__5
+
+rule__Flow__Group_11_4_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__5__Impl
-	rule__BusinessRuleTaskFlowElement__Group__6
+	rule__Flow__Group_11_4_1__0__Impl
+	rule__Flow__Group_11_4_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__5__Impl
+rule__Flow__Group_11_4_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); }
-	(rule__BusinessRuleTaskFlowElement__Group_5__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); }
+	{ before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__6
+rule__Flow__Group_11_4_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__6__Impl
-	rule__BusinessRuleTaskFlowElement__Group__7
+	rule__Flow__Group_11_4_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__6__Impl
+rule__Flow__Group_11_4_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6()); }
-	(rule__BusinessRuleTaskFlowElement__Group_6__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6()); }
+	{ before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); }
+	(rule__Flow__ExclElementsAssignment_11_4_1_1)
+	{ after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__7
+
+rule__Test__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__7__Impl
-	rule__BusinessRuleTaskFlowElement__Group__8
+	rule__Test__Group__0__Impl
+	rule__Test__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__7__Impl
+rule__Test__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7()); }
-	(rule__BusinessRuleTaskFlowElement__Group_7__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7()); }
+	{ before(grammarAccess.getTestAccess().getTestKeyword_0()); }
+	'Test'
+	{ after(grammarAccess.getTestAccess().getTestKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__8
+rule__Test__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__8__Impl
-	rule__BusinessRuleTaskFlowElement__Group__9
+	rule__Test__Group__1__Impl
+	rule__Test__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__8__Impl
+rule__Test__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_8()); }
-	(rule__BusinessRuleTaskFlowElement__Group_8__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_8()); }
+	{ before(grammarAccess.getTestAccess().getNameAssignment_1()); }
+	(rule__Test__NameAssignment_1)
+	{ after(grammarAccess.getTestAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__9
+rule__Test__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group__9__Impl
+	rule__Test__Group__2__Impl
+	rule__Test__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group__9__Impl
+rule__Test__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); }
+	{ before(grammarAccess.getTestAccess().getForKeyword_2()); }
+	'for'
+	{ after(grammarAccess.getTestAccess().getForKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__BusinessRuleTaskFlowElement__Group_4__0
+rule__Test__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_4__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_4__1
+	rule__Test__Group__3__Impl
+	rule__Test__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__0__Impl
+rule__Test__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); }
+	{ before(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); }
+	(rule__Test__FlowReferenceAssignment_3)
+	{ after(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__1
+rule__Test__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_4__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group_4__2
+	rule__Test__Group__4__Impl
+	rule__Test__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__1__Impl
+rule__Test__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); }
-	'resultVariable'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); }
+	{ before(grammarAccess.getTestAccess().getGroup_4()); }
+	(rule__Test__Group_4__0)?
+	{ after(grammarAccess.getTestAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__2
+rule__Test__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_4__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group_4__3
+	rule__Test__Group__5__Impl
+	rule__Test__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__2__Impl
+rule__Test__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	{ before(grammarAccess.getTestAccess().getGroup_5()); }
+	(rule__Test__Group_5__0)?
+	{ after(grammarAccess.getTestAccess().getGroup_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__3
+rule__Test__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
+	rule__Test__Group__6__Impl
+	rule__Test__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
+rule__Test__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); }
-	(rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); }
+	{ before(grammarAccess.getTestAccess().getEndCheckAssignment_6()); }
+	(rule__Test__EndCheckAssignment_6)?
+	{ after(grammarAccess.getTestAccess().getEndCheckAssignment_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__BusinessRuleTaskFlowElement__Group_5__0
+rule__Test__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__1
+	rule__Test__Group__7__Impl
+	rule__Test__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__0__Impl
+rule__Test__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_5_0()); }
-	'with'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_5_0()); }
+	{ before(grammarAccess.getTestAccess().getGroup_7()); }
+	(rule__Test__Group_7__0)?
+	{ after(grammarAccess.getTestAccess().getGroup_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__1
+rule__Test__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__2
+	rule__Test__Group__8__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__1__Impl
+rule__Test__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedKeyword_5_1()); }
-	'hardcoded'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedKeyword_5_1()); }
+	{ before(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	RULE_DECLARATION_FINISHED
+	{ after(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__2
+
+rule__Test__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__3
+	rule__Test__Group_4__0__Impl
+	rule__Test__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__2__Impl
+rule__Test__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputsKeyword_5_2()); }
-	'inputs'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputsKeyword_5_2()); }
+	{ before(grammarAccess.getTestAccess().getWithKeyword_4_0()); }
+	'with'
+	{ after(grammarAccess.getTestAccess().getWithKeyword_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__3
+rule__Test__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__3__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__4
+	rule__Test__Group_4__1__Impl
+	rule__Test__Group_4__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__3__Impl
+rule__Test__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_3()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_3()); }
+	{ before(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); }
+	'priority'
+	{ after(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__4
+rule__Test__Group_4__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__4__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__5
+	rule__Test__Group_4__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__4__Impl
+rule__Test__Group_4__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_4()); }
+	{ before(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); }
+	(rule__Test__PriorityAssignment_4_2)
+	{ after(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__5
+
+rule__Test__Group_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__5__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5__6
+	rule__Test__Group_5__0__Impl
+	rule__Test__Group_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__5__Impl
+rule__Test__Group_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5()); }
-	(rule__BusinessRuleTaskFlowElement__Group_5_5__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5()); }
+	{ before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); }
+	(rule__Test__DeclarationsAssignment_5_0)
+	{ after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__6
+rule__Test__Group_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5__6__Impl
+	rule__Test__Group_5__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5__6__Impl
+rule__Test__Group_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_6()); }
+	{ before(grammarAccess.getTestAccess().getGroup_5_1()); }
+	(rule__Test__Group_5_1__0)*
+	{ after(grammarAccess.getTestAccess().getGroup_5_1()); }
 )
 ;
 finally {
@@ -9546,53 +9525,53 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_5_5__0
+rule__Test__Group_5_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5_5__1
+	rule__Test__Group_5_1__0__Impl
+	rule__Test__Group_5_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl
+rule__Test__Group_5_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_0()); }
-	(rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_0()); }
+	{ before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5__1
+rule__Test__Group_5_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl
+	rule__Test__Group_5_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl
+rule__Test__Group_5_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5_1()); }
-	(rule__BusinessRuleTaskFlowElement__Group_5_5_1__0)*
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5_1()); }
+	{ before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); }
+	(rule__Test__DeclarationsAssignment_5_1_1)
+	{ after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); }
 )
 ;
 finally {
@@ -9600,215 +9579,215 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_5_5_1__0
+rule__Test__Group_7__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_5_5_1__1
+	rule__Test__Group_7__0__Impl
+	rule__Test__Group_7__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl
+rule__Test__Group_7__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_5_1_0()); }
+	{ before(grammarAccess.getTestAccess().getWithKeyword_7_0()); }
+	'with'
+	{ after(grammarAccess.getTestAccess().getWithKeyword_7_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5_1__1
+rule__Test__Group_7__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl
+	rule__Test__Group_7__1__Impl
+	rule__Test__Group_7__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl
+rule__Test__Group_7__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_1_1()); }
-	(rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_1_1()); }
+	{ before(grammarAccess.getTestAccess().getMocksKeyword_7_1()); }
+	'mocks'
+	{ after(grammarAccess.getTestAccess().getMocksKeyword_7_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__BusinessRuleTaskFlowElement__Group_6__0
+rule__Test__Group_7__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6__1
+	rule__Test__Group_7__2__Impl
+	rule__Test__Group_7__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__0__Impl
+rule__Test__Group_7__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_6_0()); }
-	'with'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_6_0()); }
+	{ before(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__1
+rule__Test__Group_7__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6__2
+	rule__Test__Group_7__3__Impl
+	rule__Test__Group_7__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__1__Impl
+rule__Test__Group_7__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesKeyword_6_1()); }
-	'inputVariables'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesKeyword_6_1()); }
+	{ before(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__2
+rule__Test__Group_7__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6__3
+	rule__Test__Group_7__4__Impl
+	rule__Test__Group_7__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__2__Impl
+rule__Test__Group_7__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); }
+	{ before(grammarAccess.getTestAccess().getGroup_7_4()); }
+	(rule__Test__Group_7_4__0)?
+	{ after(grammarAccess.getTestAccess().getGroup_7_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__3
+rule__Test__Group_7__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__3__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6__4
+	rule__Test__Group_7__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__3__Impl
+rule__Test__Group_7__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); }
+	{ before(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__4
+
+rule__Test__Group_7_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__4__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6__5
+	rule__Test__Group_7_4__0__Impl
+	rule__Test__Group_7_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__4__Impl
+rule__Test__Group_7_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4()); }
-	(rule__BusinessRuleTaskFlowElement__Group_6_4__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4()); }
+	{ before(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); }
+	(rule__Test__MocksAssignment_7_4_0)
+	{ after(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__5
+rule__Test__Group_7_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6__5__Impl
+	rule__Test__Group_7_4__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6__5__Impl
+rule__Test__Group_7_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); }
+	{ before(grammarAccess.getTestAccess().getGroup_7_4_1()); }
+	(rule__Test__Group_7_4_1__0)*
+	{ after(grammarAccess.getTestAccess().getGroup_7_4_1()); }
 )
 ;
 finally {
@@ -9816,53 +9795,53 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_6_4__0
+rule__Test__Group_7_4_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6_4__1
+	rule__Test__Group_7_4_1__0__Impl
+	rule__Test__Group_7_4_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl
+rule__Test__Group_7_4_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_0()); }
-	(rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_0()); }
+	{ before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4__1
+rule__Test__Group_7_4_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl
+	rule__Test__Group_7_4_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl
+rule__Test__Group_7_4_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4_1()); }
-	(rule__BusinessRuleTaskFlowElement__Group_6_4_1__0)*
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4_1()); }
+	{ before(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); }
+	(rule__Test__MocksAssignment_7_4_1_1)
+	{ after(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); }
 )
 ;
 finally {
@@ -9870,215 +9849,215 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_6_4_1__0
+rule__VariableDeclarations__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_6_4_1__1
+	rule__VariableDeclarations__Group__0__Impl
+	rule__VariableDeclarations__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl
+rule__VariableDeclarations__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); }
+	'with'
+	{ after(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4_1__1
+rule__VariableDeclarations__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl
+	rule__VariableDeclarations__Group__1__Impl
+	rule__VariableDeclarations__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl
+rule__VariableDeclarations__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_1_1()); }
-	(rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_1_1()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); }
+	'variables'
+	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__BusinessRuleTaskFlowElement__Group_7__0
+rule__VariableDeclarations__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7__1
+	rule__VariableDeclarations__Group__2__Impl
+	rule__VariableDeclarations__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__0__Impl
+rule__VariableDeclarations__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_7_0()); }
-	'with'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_7_0()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); }
+	'for'
+	{ after(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__1
+rule__VariableDeclarations__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7__2
+	rule__VariableDeclarations__Group__3__Impl
+	rule__VariableDeclarations__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__1__Impl
+rule__VariableDeclarations__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesKeyword_7_1()); }
-	'outputVariables'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesKeyword_7_1()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); }
+	(rule__VariableDeclarations__TaskReferenceAssignment_3)
+	{ after(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__2
+rule__VariableDeclarations__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7__3
+	rule__VariableDeclarations__Group__4__Impl
+	rule__VariableDeclarations__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__2__Impl
+rule__VariableDeclarations__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
+	{ after(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__3
+rule__VariableDeclarations__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__3__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7__4
+	rule__VariableDeclarations__Group__5__Impl
+	rule__VariableDeclarations__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__3__Impl
+rule__VariableDeclarations__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_7_3()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); }
 	RULE_LIST_OPEN
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_7_3()); }
+	{ after(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__4
+rule__VariableDeclarations__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__4__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7__5
+	rule__VariableDeclarations__Group__6__Impl
+	rule__VariableDeclarations__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__4__Impl
+rule__VariableDeclarations__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4()); }
-	(rule__BusinessRuleTaskFlowElement__Group_7_4__0)?
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); }
+	(rule__VariableDeclarations__Group_6__0)?
+	{ after(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__5
+rule__VariableDeclarations__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7__5__Impl
+	rule__VariableDeclarations__Group__7__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7__5__Impl
+rule__VariableDeclarations__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
 	RULE_LIST_CLOSED
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
+	{ after(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
 )
 ;
 finally {
@@ -10086,53 +10065,53 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_7_4__0
+rule__VariableDeclarations__Group_6__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7_4__1
+	rule__VariableDeclarations__Group_6__0__Impl
+	rule__VariableDeclarations__Group_6__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl
+rule__VariableDeclarations__Group_6__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_0()); }
-	(rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_0()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); }
+	(rule__VariableDeclarations__VariablesAssignment_6_0)
+	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4__1
+rule__VariableDeclarations__Group_6__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl
+	rule__VariableDeclarations__Group_6__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl
+rule__VariableDeclarations__Group_6__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4_1()); }
-	(rule__BusinessRuleTaskFlowElement__Group_7_4_1__0)*
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4_1()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); }
+	(rule__VariableDeclarations__Group_6_1__0)*
+	{ after(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); }
 )
 ;
 finally {
@@ -10140,53 +10119,53 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_7_4_1__0
+rule__VariableDeclarations__Group_6_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_7_4_1__1
+	rule__VariableDeclarations__Group_6_1__0__Impl
+	rule__VariableDeclarations__Group_6_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl
+rule__VariableDeclarations__Group_6_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
 	RULE_SEPARATOR
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
+	{ after(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4_1__1
+rule__VariableDeclarations__Group_6_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl
+	rule__VariableDeclarations__Group_6_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl
+rule__VariableDeclarations__Group_6_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_1_1()); }
-	(rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_1_1()); }
+	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); }
+	(rule__VariableDeclarations__VariablesAssignment_6_1_1)
+	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); }
 )
 ;
 finally {
@@ -10194,512 +10173,512 @@ finally {
 }
 
 
-rule__BusinessRuleTaskFlowElement__Group_8__0
+rule__EndChecks__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_8__0__Impl
-	rule__BusinessRuleTaskFlowElement__Group_8__1
+	rule__EndChecks__Group__0__Impl
+	rule__EndChecks__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__0__Impl
+rule__EndChecks__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_8_0()); }
-	'and'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_8_0()); }
+	{ before(grammarAccess.getEndChecksAccess().getWithKeyword_0()); }
+	'with'
+	{ after(grammarAccess.getEndChecksAccess().getWithKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__1
+rule__EndChecks__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_8__1__Impl
-	rule__BusinessRuleTaskFlowElement__Group_8__2
+	rule__EndChecks__Group__1__Impl
+	rule__EndChecks__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__1__Impl
+rule__EndChecks__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_8_1()); }
-	'label'
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_8_1()); }
+	{ before(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); }
+	'check'
+	{ after(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__2
+rule__EndChecks__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_8__2__Impl
-	rule__BusinessRuleTaskFlowElement__Group_8__3
+	rule__EndChecks__Group__2__Impl
+	rule__EndChecks__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__2__Impl
+rule__EndChecks__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
+	{ before(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); }
 	RULE_ASSOCIATION
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); }
+	{ after(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__3
+rule__EndChecks__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BusinessRuleTaskFlowElement__Group_8__3__Impl
+	rule__EndChecks__Group__3__Impl
+	rule__EndChecks__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__Group_8__3__Impl
+rule__EndChecks__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_8_3()); }
-	(rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3)
-	{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_8_3()); }
+	{ before(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__GatewayFlowElement__Group__0
+rule__EndChecks__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__GatewayFlowElement__Group__0__Impl
-	rule__GatewayFlowElement__Group__1
+	rule__EndChecks__Group__4__Impl
+	rule__EndChecks__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__0__Impl
+rule__EndChecks__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getEndChecksAccess().getGroup_4()); }
+	(rule__EndChecks__Group_4__0)?
+	{ after(grammarAccess.getEndChecksAccess().getGroup_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__1
+rule__EndChecks__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__GatewayFlowElement__Group__1__Impl
-	rule__GatewayFlowElement__Group__2
+	rule__EndChecks__Group__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__1__Impl
+rule__EndChecks__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); }
-	(rule__GatewayFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__2
+
+rule__EndChecks__Group_4__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__GatewayFlowElement__Group__2__Impl
-	rule__GatewayFlowElement__Group__3
+	rule__EndChecks__Group_4__0__Impl
+	rule__EndChecks__Group_4__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__2__Impl
+rule__EndChecks__Group_4__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); }
+	(rule__EndChecks__EndChecksAssignment_4_0)
+	{ after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__3
+rule__EndChecks__Group_4__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__GatewayFlowElement__Group__3__Impl
-	rule__GatewayFlowElement__Group__4
+	rule__EndChecks__Group_4__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__3__Impl
+rule__EndChecks__Group_4__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); }
-	'Gateway'
-	{ after(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); }
+	{ before(grammarAccess.getEndChecksAccess().getGroup_4_1()); }
+	(rule__EndChecks__Group_4_1__0)*
+	{ after(grammarAccess.getEndChecksAccess().getGroup_4_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__4
+
+rule__EndChecks__Group_4_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__GatewayFlowElement__Group__4__Impl
+	rule__EndChecks__Group_4_1__0__Impl
+	rule__EndChecks__Group_4_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__GatewayFlowElement__Group__4__Impl
+rule__EndChecks__Group_4_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); }
+	{ before(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__SequenceFlowElement__Group__0
+rule__EndChecks__Group_4_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__0__Impl
-	rule__SequenceFlowElement__Group__1
+	rule__EndChecks__Group_4_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__0__Impl
+rule__EndChecks__Group_4_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); }
-	'FlowElement'
-	{ after(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); }
+	{ before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); }
+	(rule__EndChecks__EndChecksAssignment_4_1_1)
+	{ after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__1
+
+rule__StringVariableDeclaration__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__1__Impl
-	rule__SequenceFlowElement__Group__2
+	rule__StringVariableDeclaration__Group__0__Impl
+	rule__StringVariableDeclaration__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__1__Impl
+rule__StringVariableDeclaration__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); }
-	(rule__SequenceFlowElement__NameAssignment_1)
-	{ after(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); }
+	(rule__StringVariableDeclaration__KeyAssignment_0)
+	{ after(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__2
+rule__StringVariableDeclaration__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__2__Impl
-	rule__SequenceFlowElement__Group__3
+	rule__StringVariableDeclaration__Group__1__Impl
+	rule__StringVariableDeclaration__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__2__Impl
+rule__StringVariableDeclaration__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	{ before(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); }
+	'='
+	{ after(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__3
+rule__StringVariableDeclaration__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__3__Impl
-	rule__SequenceFlowElement__Group__4
+	rule__StringVariableDeclaration__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__3__Impl
+rule__StringVariableDeclaration__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); }
-	'SequenceFlow'
-	{ after(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); }
+	{ before(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); }
+	(rule__StringVariableDeclaration__ValueAssignment_2)
+	{ after(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__4
+
+rule__IntVariableDeclaration__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__4__Impl
-	rule__SequenceFlowElement__Group__5
+	rule__IntVariableDeclaration__Group__0__Impl
+	rule__IntVariableDeclaration__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__4__Impl
+rule__IntVariableDeclaration__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); }
-	(rule__SequenceFlowElement__Group_4__0)?
-	{ after(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); }
+	{ before(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); }
+	(rule__IntVariableDeclaration__KeyAssignment_0)
+	{ after(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__5
+rule__IntVariableDeclaration__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group__5__Impl
+	rule__IntVariableDeclaration__Group__1__Impl
+	rule__IntVariableDeclaration__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group__5__Impl
+rule__IntVariableDeclaration__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); }
+	{ before(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); }
+	'='
+	{ after(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__SequenceFlowElement__Group_4__0
+rule__IntVariableDeclaration__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group_4__0__Impl
-	rule__SequenceFlowElement__Group_4__1
+	rule__IntVariableDeclaration__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__0__Impl
+rule__IntVariableDeclaration__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); }
+	{ before(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); }
+	(rule__IntVariableDeclaration__ValueAssignment_2)
+	{ after(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__1
+
+rule__BooleanVariableDeclaration__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group_4__1__Impl
-	rule__SequenceFlowElement__Group_4__2
+	rule__BooleanVariableDeclaration__Group__0__Impl
+	rule__BooleanVariableDeclaration__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__1__Impl
+rule__BooleanVariableDeclaration__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); }
-	'expression'
-	{ after(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); }
+	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); }
+	(rule__BooleanVariableDeclaration__KeyAssignment_0)
+	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__2
+rule__BooleanVariableDeclaration__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group_4__2__Impl
-	rule__SequenceFlowElement__Group_4__3
+	rule__BooleanVariableDeclaration__Group__1__Impl
+	rule__BooleanVariableDeclaration__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__2__Impl
+rule__BooleanVariableDeclaration__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
+	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); }
+	'='
+	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__3
+rule__BooleanVariableDeclaration__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__SequenceFlowElement__Group_4__3__Impl
+	rule__BooleanVariableDeclaration__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__SequenceFlowElement__Group_4__3__Impl
+rule__BooleanVariableDeclaration__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); }
-	(rule__SequenceFlowElement__ExpressionAssignment_4_3)
-	{ after(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); }
+	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); }
+	(rule__BooleanVariableDeclaration__ValueAssignment_2)
+	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); }
 )
 ;
 finally {
@@ -10707,80 +10686,80 @@ finally {
 }
 
 
-rule__ExternalTopic__Group__0
+rule__StringVariableEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalTopic__Group__0__Impl
-	rule__ExternalTopic__Group__1
+	rule__StringVariableEquals__Group__0__Impl
+	rule__StringVariableEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalTopic__Group__0__Impl
+rule__StringVariableEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); }
-	'ExternalTopic'
-	{ after(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); }
+	{ before(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); }
+	(rule__StringVariableEquals__KeyAssignment_0)
+	{ after(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalTopic__Group__1
+rule__StringVariableEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalTopic__Group__1__Impl
-	rule__ExternalTopic__Group__2
+	rule__StringVariableEquals__Group__1__Impl
+	rule__StringVariableEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalTopic__Group__1__Impl
+rule__StringVariableEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); }
-	(rule__ExternalTopic__NameAssignment_1)
-	{ after(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
+	'=='
+	{ after(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalTopic__Group__2
+rule__StringVariableEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__ExternalTopic__Group__2__Impl
+	rule__StringVariableEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalTopic__Group__2__Impl
+rule__StringVariableEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); }
+	{ before(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); }
+	(rule__StringVariableEquals__ValueAssignment_2)
+	{ after(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
@@ -10788,242 +10767,242 @@ finally {
 }
 
 
-rule__StringVariable__Group__0
+rule__IntVariableEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__0__Impl
-	rule__StringVariable__Group__1
+	rule__IntVariableEquals__Group__0__Impl
+	rule__IntVariableEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__0__Impl
+rule__IntVariableEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getStringKeyword_0()); }
-	'String'
-	{ after(grammarAccess.getStringVariableAccess().getStringKeyword_0()); }
+	{ before(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); }
+	(rule__IntVariableEquals__KeyAssignment_0)
+	{ after(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__1
+rule__IntVariableEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__1__Impl
-	rule__StringVariable__Group__2
+	rule__IntVariableEquals__Group__1__Impl
+	rule__IntVariableEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__1__Impl
+rule__IntVariableEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getNameAssignment_1()); }
-	(rule__StringVariable__NameAssignment_1)
-	{ after(grammarAccess.getStringVariableAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
+	'=='
+	{ after(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__2
+rule__IntVariableEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__2__Impl
-	rule__StringVariable__Group__3
+	rule__IntVariableEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__2__Impl
+rule__IntVariableEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getWithKeyword_2()); }
-	'with'
-	{ after(grammarAccess.getStringVariableAccess().getWithKeyword_2()); }
+	{ before(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); }
+	(rule__IntVariableEquals__ValueAssignment_2)
+	{ after(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__3
+
+rule__BooleanVariableEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__3__Impl
-	rule__StringVariable__Group__4
+	rule__BooleanVariableEquals__Group__0__Impl
+	rule__BooleanVariableEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__3__Impl
+rule__BooleanVariableEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); }
-	'proposals'
-	{ after(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); }
+	{ before(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); }
+	(rule__BooleanVariableEquals__KeyAssignment_0)
+	{ after(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__4
+rule__BooleanVariableEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__4__Impl
-	rule__StringVariable__Group__5
+	rule__BooleanVariableEquals__Group__1__Impl
+	rule__BooleanVariableEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__4__Impl
+rule__BooleanVariableEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	{ before(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
+	'=='
+	{ after(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__5
+rule__BooleanVariableEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__5__Impl
-	rule__StringVariable__Group__6
+	rule__BooleanVariableEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__5__Impl
+rule__BooleanVariableEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	{ before(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); }
+	(rule__BooleanVariableEquals__ValueAssignment_2)
+	{ after(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__6
+
+rule__StringVariableNotEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__6__Impl
-	rule__StringVariable__Group__7
+	rule__StringVariableNotEquals__Group__0__Impl
+	rule__StringVariableNotEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__6__Impl
+rule__StringVariableNotEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getGroup_6()); }
-	(rule__StringVariable__Group_6__0)?
-	{ after(grammarAccess.getStringVariableAccess().getGroup_6()); }
+	{ before(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); }
+	(rule__StringVariableNotEquals__KeyAssignment_0)
+	{ after(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__7
+rule__StringVariableNotEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__7__Impl
-	rule__StringVariable__Group__8
+	rule__StringVariableNotEquals__Group__1__Impl
+	rule__StringVariableNotEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__7__Impl
+rule__StringVariableNotEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	{ before(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
+	'!='
+	{ after(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__8
+rule__StringVariableNotEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group__8__Impl
+	rule__StringVariableNotEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group__8__Impl
+rule__StringVariableNotEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); }
+	(rule__StringVariableNotEquals__ValueAssignment_2)
+	{ after(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
@@ -11031,350 +11010,350 @@ finally {
 }
 
 
-rule__StringVariable__Group_6__0
+rule__IntVariableNotEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group_6__0__Impl
-	rule__StringVariable__Group_6__1
+	rule__IntVariableNotEquals__Group__0__Impl
+	rule__IntVariableNotEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6__0__Impl
+rule__IntVariableNotEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); }
-	(rule__StringVariable__ProposalsAssignment_6_0)
-	{ after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); }
+	{ before(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); }
+	(rule__IntVariableNotEquals__KeyAssignment_0)
+	{ after(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6__1
+rule__IntVariableNotEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group_6__1__Impl
+	rule__IntVariableNotEquals__Group__1__Impl
+	rule__IntVariableNotEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6__1__Impl
+rule__IntVariableNotEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getGroup_6_1()); }
-	(rule__StringVariable__Group_6_1__0)*
-	{ after(grammarAccess.getStringVariableAccess().getGroup_6_1()); }
-)
+	{ before(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
+	'!='
+	{ after(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__StringVariable__Group_6_1__0
+rule__IntVariableNotEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group_6_1__0__Impl
-	rule__StringVariable__Group_6_1__1
+	rule__IntVariableNotEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6_1__0__Impl
+rule__IntVariableNotEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	{ before(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); }
+	(rule__IntVariableNotEquals__ValueAssignment_2)
+	{ after(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6_1__1
+
+rule__BooleanVariableNotEquals__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__StringVariable__Group_6_1__1__Impl
+	rule__BooleanVariableNotEquals__Group__0__Impl
+	rule__BooleanVariableNotEquals__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__StringVariable__Group_6_1__1__Impl
+rule__BooleanVariableNotEquals__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); }
-	(rule__StringVariable__ProposalsAssignment_6_1_1)
-	{ after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); }
+	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); }
+	(rule__BooleanVariableNotEquals__KeyAssignment_0)
+	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__IntVariable__Group__0
+rule__BooleanVariableNotEquals__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__0__Impl
-	rule__IntVariable__Group__1
+	rule__BooleanVariableNotEquals__Group__1__Impl
+	rule__BooleanVariableNotEquals__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__0__Impl
+rule__BooleanVariableNotEquals__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); }
-	'Integer'
-	{ after(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); }
+	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
+	'!='
+	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__1
+rule__BooleanVariableNotEquals__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__1__Impl
-	rule__IntVariable__Group__2
+	rule__BooleanVariableNotEquals__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__1__Impl
+rule__BooleanVariableNotEquals__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getNameAssignment_1()); }
-	(rule__IntVariable__NameAssignment_1)
-	{ after(grammarAccess.getIntVariableAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); }
+	(rule__BooleanVariableNotEquals__ValueAssignment_2)
+	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__2
+
+rule__ExternalServiceMock__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__2__Impl
-	rule__IntVariable__Group__3
+	rule__ExternalServiceMock__Group__0__Impl
+	rule__ExternalServiceMock__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__2__Impl
+rule__ExternalServiceMock__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getWithKeyword_2()); }
-	'with'
-	{ after(grammarAccess.getIntVariableAccess().getWithKeyword_2()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); }
+	'ExternalServiceMock'
+	{ after(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__3
+rule__ExternalServiceMock__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__3__Impl
-	rule__IntVariable__Group__4
+	rule__ExternalServiceMock__Group__1__Impl
+	rule__ExternalServiceMock__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__3__Impl
+rule__ExternalServiceMock__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); }
-	'proposals'
-	{ after(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); }
+	(rule__ExternalServiceMock__NameAssignment_1)
+	{ after(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__4
+rule__ExternalServiceMock__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__4__Impl
-	rule__IntVariable__Group__5
+	rule__ExternalServiceMock__Group__2__Impl
+	rule__ExternalServiceMock__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__4__Impl
+rule__ExternalServiceMock__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); }
+	'for'
+	{ after(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__5
+rule__ExternalServiceMock__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__5__Impl
-	rule__IntVariable__Group__6
+	rule__ExternalServiceMock__Group__3__Impl
+	rule__ExternalServiceMock__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__5__Impl
+rule__ExternalServiceMock__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); }
+	'topic'
+	{ after(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__6
+rule__ExternalServiceMock__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__6__Impl
-	rule__IntVariable__Group__7
+	rule__ExternalServiceMock__Group__4__Impl
+	rule__ExternalServiceMock__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__6__Impl
+rule__ExternalServiceMock__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getGroup_6()); }
-	(rule__IntVariable__Group_6__0)?
-	{ after(grammarAccess.getIntVariableAccess().getGroup_6()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); }
+	(rule__ExternalServiceMock__ExternalTopicAssignment_4)
+	{ after(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__7
+rule__ExternalServiceMock__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__7__Impl
-	rule__IntVariable__Group__8
+	rule__ExternalServiceMock__Group__5__Impl
+	rule__ExternalServiceMock__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__7__Impl
+rule__ExternalServiceMock__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getGroup_5()); }
+	(rule__ExternalServiceMock__Group_5__0)?
+	{ after(grammarAccess.getExternalServiceMockAccess().getGroup_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__8
+rule__ExternalServiceMock__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group__8__Impl
+	rule__ExternalServiceMock__Group__6__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group__8__Impl
+rule__ExternalServiceMock__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
 	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ after(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
 )
 ;
 finally {
@@ -11382,53 +11361,53 @@ finally {
 }
 
 
-rule__IntVariable__Group_6__0
+rule__ExternalServiceMock__Group_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group_6__0__Impl
-	rule__IntVariable__Group_6__1
+	rule__ExternalServiceMock__Group_5__0__Impl
+	rule__ExternalServiceMock__Group_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6__0__Impl
+rule__ExternalServiceMock__Group_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); }
-	(rule__IntVariable__ProposalsAssignment_6_0)
-	{ after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); }
+	(rule__ExternalServiceMock__MockingRulesAssignment_5_0)
+	{ after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6__1
+rule__ExternalServiceMock__Group_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group_6__1__Impl
+	rule__ExternalServiceMock__Group_5__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6__1__Impl
+rule__ExternalServiceMock__Group_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getGroup_6_1()); }
-	(rule__IntVariable__Group_6_1__0)*
-	{ after(grammarAccess.getIntVariableAccess().getGroup_6_1()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); }
+	(rule__ExternalServiceMock__Group_5_1__0)*
+	{ after(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); }
 )
 ;
 finally {
@@ -11436,53 +11415,53 @@ finally {
 }
 
 
-rule__IntVariable__Group_6_1__0
+rule__ExternalServiceMock__Group_5_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group_6_1__0__Impl
-	rule__IntVariable__Group_6_1__1
+	rule__ExternalServiceMock__Group_5_1__0__Impl
+	rule__ExternalServiceMock__Group_5_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6_1__0__Impl
+rule__ExternalServiceMock__Group_5_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
 	RULE_SEPARATOR
-	{ after(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	{ after(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6_1__1
+rule__ExternalServiceMock__Group_5_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__IntVariable__Group_6_1__1__Impl
+	rule__ExternalServiceMock__Group_5_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__IntVariable__Group_6_1__1__Impl
+rule__ExternalServiceMock__Group_5_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); }
-	(rule__IntVariable__ProposalsAssignment_6_1_1)
-	{ after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); }
+	{ before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); }
+	(rule__ExternalServiceMock__MockingRulesAssignment_5_1_1)
+	{ after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); }
 )
 ;
 finally {
@@ -11490,242 +11469,242 @@ finally {
 }
 
 
-rule__BooleanVariable__Group__0
+rule__DelegateMock__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__0__Impl
-	rule__BooleanVariable__Group__1
+	rule__DelegateMock__Group__0__Impl
+	rule__DelegateMock__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__0__Impl
+rule__DelegateMock__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); }
-	'Boolean'
-	{ after(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); }
+	{ before(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); }
+	'DelegateMock'
+	{ after(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__1
+rule__DelegateMock__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__1__Impl
-	rule__BooleanVariable__Group__2
+	rule__DelegateMock__Group__1__Impl
+	rule__DelegateMock__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__1__Impl
+rule__DelegateMock__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); }
-	(rule__BooleanVariable__NameAssignment_1)
-	{ after(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); }
+	(rule__DelegateMock__NameAssignment_1)
+	{ after(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__2
+rule__DelegateMock__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__2__Impl
-	rule__BooleanVariable__Group__3
+	rule__DelegateMock__Group__2__Impl
+	rule__DelegateMock__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__2__Impl
+rule__DelegateMock__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); }
-	'with'
-	{ after(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); }
+	{ before(grammarAccess.getDelegateMockAccess().getForKeyword_2()); }
+	'for'
+	{ after(grammarAccess.getDelegateMockAccess().getForKeyword_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__3
+rule__DelegateMock__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__3__Impl
-	rule__BooleanVariable__Group__4
+	rule__DelegateMock__Group__3__Impl
+	rule__DelegateMock__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__3__Impl
+rule__DelegateMock__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); }
-	'proposals'
-	{ after(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); }
+	{ before(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); }
+	(rule__DelegateMock__ServiceTaskReferenceAssignment_3)
+	{ after(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__4
+rule__DelegateMock__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__4__Impl
-	rule__BooleanVariable__Group__5
+	rule__DelegateMock__Group__4__Impl
+	rule__DelegateMock__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__4__Impl
+rule__DelegateMock__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); }
+	{ before(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); }
+	'with'
+	{ after(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__5
+rule__DelegateMock__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__5__Impl
-	rule__BooleanVariable__Group__6
+	rule__DelegateMock__Group__5__Impl
+	rule__DelegateMock__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__5__Impl
+rule__DelegateMock__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); }
+	{ before(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); }
+	'delegate'
+	{ after(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__6
+rule__DelegateMock__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__6__Impl
-	rule__BooleanVariable__Group__7
+	rule__DelegateMock__Group__6__Impl
+	rule__DelegateMock__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__6__Impl
+rule__DelegateMock__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getGroup_6()); }
-	(rule__BooleanVariable__Group_6__0)?
-	{ after(grammarAccess.getBooleanVariableAccess().getGroup_6()); }
+	{ before(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); }
+	(rule__DelegateMock__DelegateClassAssignment_6)
+	{ after(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__7
+rule__DelegateMock__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__7__Impl
-	rule__BooleanVariable__Group__8
+	rule__DelegateMock__Group__7__Impl
+	rule__DelegateMock__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__7__Impl
+rule__DelegateMock__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
+	{ before(grammarAccess.getDelegateMockAccess().getGroup_7()); }
+	(rule__DelegateMock__Group_7__0)?
+	{ after(grammarAccess.getDelegateMockAccess().getGroup_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__8
+rule__DelegateMock__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group__8__Impl
+	rule__DelegateMock__Group__8__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group__8__Impl
+rule__DelegateMock__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ before(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
+	{ after(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
 )
 ;
 finally {
@@ -11733,53 +11712,53 @@ finally {
 }
 
 
-rule__BooleanVariable__Group_6__0
+rule__DelegateMock__Group_7__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group_6__0__Impl
-	rule__BooleanVariable__Group_6__1
+	rule__DelegateMock__Group_7__0__Impl
+	rule__DelegateMock__Group_7__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6__0__Impl
+rule__DelegateMock__Group_7__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); }
-	(rule__BooleanVariable__ProposalsAssignment_6_0)
-	{ after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); }
+	{ before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); }
+	(rule__DelegateMock__ManualMocksAssignment_7_0)
+	{ after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6__1
+rule__DelegateMock__Group_7__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group_6__1__Impl
+	rule__DelegateMock__Group_7__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6__1__Impl
+rule__DelegateMock__Group_7__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); }
-	(rule__BooleanVariable__Group_6_1__0)*
-	{ after(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); }
+	{ before(grammarAccess.getDelegateMockAccess().getGroup_7_1()); }
+	(rule__DelegateMock__Group_7_1__0)*
+	{ after(grammarAccess.getDelegateMockAccess().getGroup_7_1()); }
 )
 ;
 finally {
@@ -11787,53 +11766,53 @@ finally {
 }
 
 
-rule__BooleanVariable__Group_6_1__0
+rule__DelegateMock__Group_7_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group_6_1__0__Impl
-	rule__BooleanVariable__Group_6_1__1
+	rule__DelegateMock__Group_7_1__0__Impl
+	rule__DelegateMock__Group_7_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6_1__0__Impl
+rule__DelegateMock__Group_7_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	{ before(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); }
 	RULE_SEPARATOR
-	{ after(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
+	{ after(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6_1__1
+rule__DelegateMock__Group_7_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__BooleanVariable__Group_6_1__1__Impl
+	rule__DelegateMock__Group_7_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BooleanVariable__Group_6_1__1__Impl
+rule__DelegateMock__Group_7_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); }
-	(rule__BooleanVariable__ProposalsAssignment_6_1_1)
-	{ after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); }
+	{ before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); }
+	(rule__DelegateMock__ManualMocksAssignment_7_1_1)
+	{ after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); }
 )
 ;
 finally {
@@ -11841,998 +11820,755 @@ finally {
 }
 
 
-rule__Loop__Group__0
+rule__MockingRule__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__0__Impl
-	rule__Loop__Group__1
+	rule__MockingRule__Group__0__Impl
+	rule__MockingRule__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__0__Impl
+rule__MockingRule__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getLoopKeyword_0()); }
-	'Loop'
-	{ after(grammarAccess.getLoopAccess().getLoopKeyword_0()); }
+	{ before(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); }
+	'with'
+	{ after(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__1
+rule__MockingRule__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__1__Impl
-	rule__Loop__Group__2
+	rule__MockingRule__Group__1__Impl
+	rule__MockingRule__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__1__Impl
+rule__MockingRule__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getNameAssignment_1()); }
-	(rule__Loop__NameAssignment_1)
-	{ after(grammarAccess.getLoopAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); }
+	'rule'
+	{ after(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__2
+rule__MockingRule__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__2__Impl
-	rule__Loop__Group__3
+	rule__MockingRule__Group__2__Impl
+	rule__MockingRule__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__2__Impl
+rule__MockingRule__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getStartsKeyword_2()); }
-	'starts'
-	{ after(grammarAccess.getLoopAccess().getStartsKeyword_2()); }
+	{ before(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); }
+	RULE_ASSOCIATION
+	{ after(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__3
+rule__MockingRule__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__3__Impl
-	rule__Loop__Group__4
+	rule__MockingRule__Group__3__Impl
+	rule__MockingRule__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__3__Impl
+rule__MockingRule__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getWithKeyword_3()); }
-	'with'
-	{ after(grammarAccess.getLoopAccess().getWithKeyword_3()); }
+	{ before(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); }
+	'if'
+	{ after(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__4
+rule__MockingRule__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__4__Impl
-	rule__Loop__Group__5
+	rule__MockingRule__Group__4__Impl
+	rule__MockingRule__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__4__Impl
+rule__MockingRule__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getStartAssignment_4()); }
-	(rule__Loop__StartAssignment_4)
-	{ after(grammarAccess.getLoopAccess().getStartAssignment_4()); }
+	{ before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__5
+rule__MockingRule__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__5__Impl
-	rule__Loop__Group__6
+	rule__MockingRule__Group__5__Impl
+	rule__MockingRule__Group__6
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__5__Impl
+rule__MockingRule__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getFollowsKeyword_5()); }
-	'follows'
-	{ after(grammarAccess.getLoopAccess().getFollowsKeyword_5()); }
+	{ before(grammarAccess.getMockingRuleAccess().getGroup_5()); }
+	(rule__MockingRule__Group_5__0)?
+	{ after(grammarAccess.getMockingRuleAccess().getGroup_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__6
+rule__MockingRule__Group__6
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__6__Impl
-	rule__Loop__Group__7
+	rule__MockingRule__Group__6__Impl
+	rule__MockingRule__Group__7
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__6__Impl
+rule__MockingRule__Group__6__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getByKeyword_6()); }
-	'by'
-	{ after(grammarAccess.getLoopAccess().getByKeyword_6()); }
+	{ before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__7
+rule__MockingRule__Group__7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__7__Impl
-	rule__Loop__Group__8
+	rule__MockingRule__Group__7__Impl
+	rule__MockingRule__Group__8
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__7__Impl
+rule__MockingRule__Group__7__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getFollowerAssignment_7()); }
-	(rule__Loop__FollowerAssignment_7)
-	{ after(grammarAccess.getLoopAccess().getFollowerAssignment_7()); }
+	{ before(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); }
+	'set'
+	{ after(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__8
+rule__MockingRule__Group__8
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__8__Impl
-	rule__Loop__Group__9
+	rule__MockingRule__Group__8__Impl
+	rule__MockingRule__Group__9
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__8__Impl
+rule__MockingRule__Group__8__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getEndsKeyword_8()); }
-	'ends'
-	{ after(grammarAccess.getLoopAccess().getEndsKeyword_8()); }
+	{ before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); }
+	RULE_LIST_OPEN
+	{ after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__9
+rule__MockingRule__Group__9
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__9__Impl
-	rule__Loop__Group__10
+	rule__MockingRule__Group__9__Impl
+	rule__MockingRule__Group__10
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__9__Impl
+rule__MockingRule__Group__9__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getWithKeyword_9()); }
-	'with'
-	{ after(grammarAccess.getLoopAccess().getWithKeyword_9()); }
+	{ before(grammarAccess.getMockingRuleAccess().getGroup_9()); }
+	(rule__MockingRule__Group_9__0)?
+	{ after(grammarAccess.getMockingRuleAccess().getGroup_9()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__10
+rule__MockingRule__Group__10
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__10__Impl
-	rule__Loop__Group__11
+	rule__MockingRule__Group__10__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__10__Impl
+rule__MockingRule__Group__10__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getEndAssignment_10()); }
-	(rule__Loop__EndAssignment_10)
-	{ after(grammarAccess.getLoopAccess().getEndAssignment_10()); }
+	{ before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
+	RULE_LIST_CLOSED
+	{ after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__11
+
+rule__MockingRule__Group_5__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__11__Impl
-	rule__Loop__Group__12
+	rule__MockingRule__Group_5__0__Impl
+	rule__MockingRule__Group_5__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__11__Impl
+rule__MockingRule__Group_5__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getHasKeyword_11()); }
-	'has'
-	{ after(grammarAccess.getLoopAccess().getHasKeyword_11()); }
+	{ before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); }
+	(rule__MockingRule__ComparisonsAssignment_5_0)
+	{ after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__12
+rule__MockingRule__Group_5__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__12__Impl
-	rule__Loop__Group__13
+	rule__MockingRule__Group_5__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__12__Impl
+rule__MockingRule__Group_5__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getComplexityKeyword_12()); }
-	'complexity'
-	{ after(grammarAccess.getLoopAccess().getComplexityKeyword_12()); }
+	{ before(grammarAccess.getMockingRuleAccess().getGroup_5_1()); }
+	(rule__MockingRule__Group_5_1__0)*
+	{ after(grammarAccess.getMockingRuleAccess().getGroup_5_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__13
+
+rule__MockingRule__Group_5_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__13__Impl
-	rule__Loop__Group__14
+	rule__MockingRule__Group_5_1__0__Impl
+	rule__MockingRule__Group_5_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__13__Impl
+rule__MockingRule__Group_5_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getComplexityAssignment_13()); }
-	(rule__Loop__ComplexityAssignment_13)
-	{ after(grammarAccess.getLoopAccess().getComplexityAssignment_13()); }
+	{ before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__14
+rule__MockingRule__Group_5_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__14__Impl
-	rule__Loop__Group__15
+	rule__MockingRule__Group_5_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__14__Impl
+rule__MockingRule__Group_5_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getPassedKeyword_14()); }
-	'passed'
-	{ after(grammarAccess.getLoopAccess().getPassedKeyword_14()); }
+	{ before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); }
+	(rule__MockingRule__ComparisonsAssignment_5_1_1)
+	{ after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__15
+
+rule__MockingRule__Group_9__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__15__Impl
-	rule__Loop__Group__16
+	rule__MockingRule__Group_9__0__Impl
+	rule__MockingRule__Group_9__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__15__Impl
+rule__MockingRule__Group_9__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); }
+	{ before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); }
+	(rule__MockingRule__VariablesAssignment_9_0)
+	{ after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__16
+rule__MockingRule__Group_9__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__16__Impl
-	rule__Loop__Group__17
+	rule__MockingRule__Group_9__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__16__Impl
+rule__MockingRule__Group_9__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); }
+	{ before(grammarAccess.getMockingRuleAccess().getGroup_9_1()); }
+	(rule__MockingRule__Group_9_1__0)*
+	{ after(grammarAccess.getMockingRuleAccess().getGroup_9_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__17
+
+rule__MockingRule__Group_9_1__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__17__Impl
-	rule__Loop__Group__18
+	rule__MockingRule__Group_9_1__0__Impl
+	rule__MockingRule__Group_9_1__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__17__Impl
+rule__MockingRule__Group_9_1__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getGroup_17()); }
-	(rule__Loop__Group_17__0)?
-	{ after(grammarAccess.getLoopAccess().getGroup_17()); }
+	{ before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
+	RULE_SEPARATOR
+	{ after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__18
+rule__MockingRule__Group_9_1__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__18__Impl
-	rule__Loop__Group__19
+	rule__MockingRule__Group_9_1__1__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__18__Impl
+rule__MockingRule__Group_9_1__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); }
+	{ before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); }
+	(rule__MockingRule__VariablesAssignment_9_1_1)
+	{ after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__19
+
+rule__ManualMock__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group__19__Impl
+	rule__ManualMock__Group__0__Impl
+	rule__ManualMock__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group__19__Impl
+rule__ManualMock__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); }
+	{ before(grammarAccess.getManualMockAccess().getWithKeyword_0()); }
+	'with'
+	{ after(grammarAccess.getManualMockAccess().getWithKeyword_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__Loop__Group_17__0
+rule__ManualMock__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group_17__0__Impl
-	rule__Loop__Group_17__1
+	rule__ManualMock__Group__1__Impl
+	rule__ManualMock__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17__0__Impl
+rule__ManualMock__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); }
-	(rule__Loop__FrequenciesAssignment_17_0)
-	{ after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); }
+	{ before(grammarAccess.getManualMockAccess().getManualKeyword_1()); }
+	'manual'
+	{ after(grammarAccess.getManualMockAccess().getManualKeyword_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17__1
+rule__ManualMock__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group_17__1__Impl
+	rule__ManualMock__Group__2__Impl
+	rule__ManualMock__Group__3
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17__1__Impl
+rule__ManualMock__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getGroup_17_1()); }
-	(rule__Loop__Group_17_1__0)*
-	{ after(grammarAccess.getLoopAccess().getGroup_17_1()); }
+	{ before(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); }
+	(rule__ManualMock__ServiceNameAssignment_2)
+	{ after(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__Loop__Group_17_1__0
+rule__ManualMock__Group__3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group_17_1__0__Impl
-	rule__Loop__Group_17_1__1
+	rule__ManualMock__Group__3__Impl
+	rule__ManualMock__Group__4
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17_1__0__Impl
+rule__ManualMock__Group__3__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); }
+	{ before(grammarAccess.getManualMockAccess().getByKeyword_3()); }
+	'by'
+	{ after(grammarAccess.getManualMockAccess().getByKeyword_3()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17_1__1
+rule__ManualMock__Group__4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Loop__Group_17_1__1__Impl
+	rule__ManualMock__Group__4__Impl
+	rule__ManualMock__Group__5
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Loop__Group_17_1__1__Impl
+rule__ManualMock__Group__4__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); }
-	(rule__Loop__FrequenciesAssignment_17_1_1)
-	{ after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); }
+	{ before(grammarAccess.getManualMockAccess().getSetterKeyword_4()); }
+	'setter'
+	{ after(grammarAccess.getManualMockAccess().getSetterKeyword_4()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-
-rule__Flow__Group__0
+rule__ManualMock__Group__5
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Flow__Group__0__Impl
-	rule__Flow__Group__1
+	rule__ManualMock__Group__5__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__0__Impl
+rule__ManualMock__Group__5__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getFlowAccess().getFlowKeyword_0()); }
-	'Flow'
-	{ after(grammarAccess.getFlowAccess().getFlowKeyword_0()); }
+	{ before(grammarAccess.getManualMockAccess().getSetterAssignment_5()); }
+	(rule__ManualMock__SetterAssignment_5)
+	{ after(grammarAccess.getManualMockAccess().getSetterAssignment_5()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__1
+
+rule__StringCompare__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Flow__Group__1__Impl
-	rule__Flow__Group__2
+	rule__StringCompare__Group__0__Impl
+	rule__StringCompare__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__1__Impl
+rule__StringCompare__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getFlowAccess().getNameAssignment_1()); }
-	(rule__Flow__NameAssignment_1)
-	{ after(grammarAccess.getFlowAccess().getNameAssignment_1()); }
+	{ before(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); }
+	(rule__StringCompare__KeyAssignment_0)
+	{ after(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__2
+rule__StringCompare__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Flow__Group__2__Impl
-	rule__Flow__Group__3
+	rule__StringCompare__Group__1__Impl
+	rule__StringCompare__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__2__Impl
+rule__StringCompare__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getFlowAccess().getForKeyword_2()); }
-	'for'
-	{ after(grammarAccess.getFlowAccess().getForKeyword_2()); }
+	{ before(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); }
+	(rule__StringCompare__CompareSymbolAssignment_1)
+	{ after(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); }
 )
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__3
+rule__StringCompare__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Flow__Group__3__Impl
-	rule__Flow__Group__4
+	rule__StringCompare__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group__3__Impl
+rule__StringCompare__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); }
-	(rule__Flow__BpmnReferenceAssignment_3)
-	{ after(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__4__Impl
-	rule__Flow__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_4()); }
-	(rule__Flow__Group_4__0)?
-	{ after(grammarAccess.getFlowAccess().getGroup_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__5__Impl
-	rule__Flow__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getWithKeyword_5()); }
-	'with'
-	{ after(grammarAccess.getFlowAccess().getWithKeyword_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__6__Impl
-	rule__Flow__Group__7
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getElementsKeyword_6()); }
-	'elements'
-	{ after(grammarAccess.getFlowAccess().getElementsKeyword_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__7__Impl
-	rule__Flow__Group__8
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__7__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__8
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__8__Impl
-	rule__Flow__Group__9
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__8__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__9
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__9__Impl
-	rule__Flow__Group__10
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__9__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_9()); }
-	(rule__Flow__Group_9__0)?
-	{ after(grammarAccess.getFlowAccess().getGroup_9()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__10
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__10__Impl
-	rule__Flow__Group__11
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__10__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__11
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__11__Impl
-	rule__Flow__Group__12
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__11__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_11()); }
-	(rule__Flow__Group_11__0)?
-	{ after(grammarAccess.getFlowAccess().getGroup_11()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__12
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group__12__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group__12__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); }
+	{ before(grammarAccess.getStringCompareAccess().getValueAssignment_2()); }
+	(rule__StringCompare__ValueAssignment_2)
+	{ after(grammarAccess.getStringCompareAccess().getValueAssignment_2()); }
 )
 ;
 finally {
@@ -12840,4996 +12576,661 @@ finally {
 }
 
 
-rule__Flow__Group_4__0
+rule__IntCompare__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	rule__Flow__Group_4__0__Impl
-	rule__Flow__Group_4__1
+	rule__IntCompare__Group__0__Impl
+	rule__IntCompare__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__Flow__Group_4__0__Impl
+rule__IntCompare__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 (
-	{ before(grammarAccess.getFlowAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getFlowAccess().getWithKeyword_4_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_4__1__Impl
-	rule__Flow__Group_4__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); }
-	'flag'
-	{ after(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_4__2__Impl
-	rule__Flow__Group_4__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_4__3__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_4__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); }
-	(rule__Flow__FlagAssignment_4_3)
-	{ after(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Flow__Group_9__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_9__0__Impl
-	rule__Flow__Group_9__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); }
-	(rule__Flow__InclElementsAssignment_9_0)
-	{ after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_9__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_9_1()); }
-	(rule__Flow__Group_9_1__0)*
-	{ after(grammarAccess.getFlowAccess().getGroup_9_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Flow__Group_9_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_9_1__0__Impl
-	rule__Flow__Group_9_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_9_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_9_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); }
-	(rule__Flow__InclElementsAssignment_9_1_1)
-	{ after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Flow__Group_11__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__0__Impl
-	rule__Flow__Group_11__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); }
-	'without'
-	{ after(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__1__Impl
-	rule__Flow__Group_11__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); }
-	'elements'
-	{ after(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__2__Impl
-	rule__Flow__Group_11__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__3__Impl
-	rule__Flow__Group_11__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__4__Impl
-	rule__Flow__Group_11__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_11_4()); }
-	(rule__Flow__Group_11_4__0)?
-	{ after(grammarAccess.getFlowAccess().getGroup_11_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11__5__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Flow__Group_11_4__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11_4__0__Impl
-	rule__Flow__Group_11_4__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); }
-	(rule__Flow__ExclElementsAssignment_11_4_0)
-	{ after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11_4__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getGroup_11_4_1()); }
-	(rule__Flow__Group_11_4_1__0)*
-	{ after(grammarAccess.getFlowAccess().getGroup_11_4_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Flow__Group_11_4_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11_4_1__0__Impl
-	rule__Flow__Group_11_4_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Flow__Group_11_4_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Flow__Group_11_4_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); }
-	(rule__Flow__ExclElementsAssignment_11_4_1_1)
-	{ after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__0__Impl
-	rule__Test__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getTestKeyword_0()); }
-	'Test'
-	{ after(grammarAccess.getTestAccess().getTestKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__1__Impl
-	rule__Test__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getNameAssignment_1()); }
-	(rule__Test__NameAssignment_1)
-	{ after(grammarAccess.getTestAccess().getNameAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__2__Impl
-	rule__Test__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getForKeyword_2()); }
-	'for'
-	{ after(grammarAccess.getTestAccess().getForKeyword_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__3__Impl
-	rule__Test__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); }
-	(rule__Test__FlowReferenceAssignment_3)
-	{ after(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__4__Impl
-	rule__Test__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_4()); }
-	(rule__Test__Group_4__0)?
-	{ after(grammarAccess.getTestAccess().getGroup_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__5__Impl
-	rule__Test__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_5()); }
-	(rule__Test__Group_5__0)?
-	{ after(grammarAccess.getTestAccess().getGroup_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__6__Impl
-	rule__Test__Group__7
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getEndCheckAssignment_6()); }
-	(rule__Test__EndCheckAssignment_6)?
-	{ after(grammarAccess.getTestAccess().getEndCheckAssignment_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__7__Impl
-	rule__Test__Group__8
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__7__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_7()); }
-	(rule__Test__Group_7__0)?
-	{ after(grammarAccess.getTestAccess().getGroup_7()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__8
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group__8__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group__8__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_4__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_4__0__Impl
-	rule__Test__Group_4__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_4__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getWithKeyword_4_0()); }
-	'with'
-	{ after(grammarAccess.getTestAccess().getWithKeyword_4_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_4__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_4__1__Impl
-	rule__Test__Group_4__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_4__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); }
-	'priority'
-	{ after(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_4__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_4__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_4__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); }
-	(rule__Test__PriorityAssignment_4_2)
-	{ after(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_5__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_5__0__Impl
-	rule__Test__Group_5__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); }
-	(rule__Test__DeclarationsAssignment_5_0)
-	{ after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_5__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_5_1()); }
-	(rule__Test__Group_5_1__0)*
-	{ after(grammarAccess.getTestAccess().getGroup_5_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_5_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_5_1__0__Impl
-	rule__Test__Group_5_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_5_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_5_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); }
-	(rule__Test__DeclarationsAssignment_5_1_1)
-	{ after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_7__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__0__Impl
-	rule__Test__Group_7__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getWithKeyword_7_0()); }
-	'with'
-	{ after(grammarAccess.getTestAccess().getWithKeyword_7_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__1__Impl
-	rule__Test__Group_7__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getMocksKeyword_7_1()); }
-	'mocks'
-	{ after(grammarAccess.getTestAccess().getMocksKeyword_7_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__2__Impl
-	rule__Test__Group_7__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__3__Impl
-	rule__Test__Group_7__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__4__Impl
-	rule__Test__Group_7__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_7_4()); }
-	(rule__Test__Group_7_4__0)?
-	{ after(grammarAccess.getTestAccess().getGroup_7_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7__5__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_7_4__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7_4__0__Impl
-	rule__Test__Group_7_4__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); }
-	(rule__Test__MocksAssignment_7_4_0)
-	{ after(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7_4__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getGroup_7_4_1()); }
-	(rule__Test__Group_7_4_1__0)*
-	{ after(grammarAccess.getTestAccess().getGroup_7_4_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Test__Group_7_4_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7_4_1__0__Impl
-	rule__Test__Group_7_4_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__Test__Group_7_4_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__Test__Group_7_4_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); }
-	(rule__Test__MocksAssignment_7_4_1_1)
-	{ after(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__VariableDeclarations__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__0__Impl
-	rule__VariableDeclarations__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); }
-	'with'
-	{ after(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__1__Impl
-	rule__VariableDeclarations__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); }
-	'variables'
-	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__2__Impl
-	rule__VariableDeclarations__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); }
-	'for'
-	{ after(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__3__Impl
-	rule__VariableDeclarations__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); }
-	(rule__VariableDeclarations__TaskReferenceAssignment_3)
-	{ after(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__4__Impl
-	rule__VariableDeclarations__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__5__Impl
-	rule__VariableDeclarations__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__6__Impl
-	rule__VariableDeclarations__Group__7
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); }
-	(rule__VariableDeclarations__Group_6__0)?
-	{ after(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group__7__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group__7__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__VariableDeclarations__Group_6__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group_6__0__Impl
-	rule__VariableDeclarations__Group_6__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); }
-	(rule__VariableDeclarations__VariablesAssignment_6_0)
-	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group_6__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); }
-	(rule__VariableDeclarations__Group_6_1__0)*
-	{ after(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__VariableDeclarations__Group_6_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group_6_1__0__Impl
-	rule__VariableDeclarations__Group_6_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__VariableDeclarations__Group_6_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__VariableDeclarations__Group_6_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); }
-	(rule__VariableDeclarations__VariablesAssignment_6_1_1)
-	{ after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__EndChecks__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__0__Impl
-	rule__EndChecks__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getWithKeyword_0()); }
-	'with'
-	{ after(grammarAccess.getEndChecksAccess().getWithKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__1__Impl
-	rule__EndChecks__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); }
-	'check'
-	{ after(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__2__Impl
-	rule__EndChecks__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__3__Impl
-	rule__EndChecks__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__4__Impl
-	rule__EndChecks__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getGroup_4()); }
-	(rule__EndChecks__Group_4__0)?
-	{ after(grammarAccess.getEndChecksAccess().getGroup_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group__5__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__EndChecks__Group_4__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group_4__0__Impl
-	rule__EndChecks__Group_4__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); }
-	(rule__EndChecks__EndChecksAssignment_4_0)
-	{ after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group_4__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getGroup_4_1()); }
-	(rule__EndChecks__Group_4_1__0)*
-	{ after(grammarAccess.getEndChecksAccess().getGroup_4_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__EndChecks__Group_4_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group_4_1__0__Impl
-	rule__EndChecks__Group_4_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__EndChecks__Group_4_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndChecks__Group_4_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); }
-	(rule__EndChecks__EndChecksAssignment_4_1_1)
-	{ after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__StringVariableDeclaration__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableDeclaration__Group__0__Impl
-	rule__StringVariableDeclaration__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableDeclaration__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); }
-	(rule__StringVariableDeclaration__KeyAssignment_0)
-	{ after(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableDeclaration__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableDeclaration__Group__1__Impl
-	rule__StringVariableDeclaration__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableDeclaration__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-	'='
-	{ after(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableDeclaration__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableDeclaration__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableDeclaration__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); }
-	(rule__StringVariableDeclaration__ValueAssignment_2)
-	{ after(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__IntVariableDeclaration__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableDeclaration__Group__0__Impl
-	rule__IntVariableDeclaration__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableDeclaration__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); }
-	(rule__IntVariableDeclaration__KeyAssignment_0)
-	{ after(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableDeclaration__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableDeclaration__Group__1__Impl
-	rule__IntVariableDeclaration__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableDeclaration__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-	'='
-	{ after(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableDeclaration__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableDeclaration__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableDeclaration__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); }
-	(rule__IntVariableDeclaration__ValueAssignment_2)
-	{ after(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__BooleanVariableDeclaration__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableDeclaration__Group__0__Impl
-	rule__BooleanVariableDeclaration__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableDeclaration__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); }
-	(rule__BooleanVariableDeclaration__KeyAssignment_0)
-	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableDeclaration__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableDeclaration__Group__1__Impl
-	rule__BooleanVariableDeclaration__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableDeclaration__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-	'='
-	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableDeclaration__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableDeclaration__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableDeclaration__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); }
-	(rule__BooleanVariableDeclaration__ValueAssignment_2)
-	{ after(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__StringVariableEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableEquals__Group__0__Impl
-	rule__StringVariableEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); }
-	(rule__StringVariableEquals__KeyAssignment_0)
-	{ after(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableEquals__Group__1__Impl
-	rule__StringVariableEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-	'=='
-	{ after(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); }
-	(rule__StringVariableEquals__ValueAssignment_2)
-	{ after(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__IntVariableEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableEquals__Group__0__Impl
-	rule__IntVariableEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); }
-	(rule__IntVariableEquals__KeyAssignment_0)
-	{ after(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableEquals__Group__1__Impl
-	rule__IntVariableEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-	'=='
-	{ after(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); }
-	(rule__IntVariableEquals__ValueAssignment_2)
-	{ after(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__BooleanVariableEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableEquals__Group__0__Impl
-	rule__BooleanVariableEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); }
-	(rule__BooleanVariableEquals__KeyAssignment_0)
-	{ after(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableEquals__Group__1__Impl
-	rule__BooleanVariableEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-	'=='
-	{ after(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); }
-	(rule__BooleanVariableEquals__ValueAssignment_2)
-	{ after(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__StringVariableNotEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableNotEquals__Group__0__Impl
-	rule__StringVariableNotEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableNotEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); }
-	(rule__StringVariableNotEquals__KeyAssignment_0)
-	{ after(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableNotEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableNotEquals__Group__1__Impl
-	rule__StringVariableNotEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableNotEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-	'!='
-	{ after(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableNotEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringVariableNotEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringVariableNotEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); }
-	(rule__StringVariableNotEquals__ValueAssignment_2)
-	{ after(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__IntVariableNotEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableNotEquals__Group__0__Impl
-	rule__IntVariableNotEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableNotEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); }
-	(rule__IntVariableNotEquals__KeyAssignment_0)
-	{ after(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableNotEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableNotEquals__Group__1__Impl
-	rule__IntVariableNotEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableNotEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-	'!='
-	{ after(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableNotEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntVariableNotEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntVariableNotEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); }
-	(rule__IntVariableNotEquals__ValueAssignment_2)
-	{ after(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__BooleanVariableNotEquals__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableNotEquals__Group__0__Impl
-	rule__BooleanVariableNotEquals__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableNotEquals__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); }
-	(rule__BooleanVariableNotEquals__KeyAssignment_0)
-	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableNotEquals__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableNotEquals__Group__1__Impl
-	rule__BooleanVariableNotEquals__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableNotEquals__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-	'!='
-	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableNotEquals__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanVariableNotEquals__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanVariableNotEquals__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); }
-	(rule__BooleanVariableNotEquals__ValueAssignment_2)
-	{ after(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__ExternalServiceMock__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__0__Impl
-	rule__ExternalServiceMock__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); }
-	'ExternalServiceMock'
-	{ after(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__1__Impl
-	rule__ExternalServiceMock__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); }
-	(rule__ExternalServiceMock__NameAssignment_1)
-	{ after(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__2__Impl
-	rule__ExternalServiceMock__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); }
-	'for'
-	{ after(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__3__Impl
-	rule__ExternalServiceMock__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); }
-	'topic'
-	{ after(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__4__Impl
-	rule__ExternalServiceMock__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); }
-	(rule__ExternalServiceMock__ExternalTopicAssignment_4)
-	{ after(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__5__Impl
-	rule__ExternalServiceMock__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getGroup_5()); }
-	(rule__ExternalServiceMock__Group_5__0)?
-	{ after(grammarAccess.getExternalServiceMockAccess().getGroup_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group__6__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__ExternalServiceMock__Group_5__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group_5__0__Impl
-	rule__ExternalServiceMock__Group_5__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); }
-	(rule__ExternalServiceMock__MockingRulesAssignment_5_0)
-	{ after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group_5__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); }
-	(rule__ExternalServiceMock__Group_5_1__0)*
-	{ after(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__ExternalServiceMock__Group_5_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group_5_1__0__Impl
-	rule__ExternalServiceMock__Group_5_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ExternalServiceMock__Group_5_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ExternalServiceMock__Group_5_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); }
-	(rule__ExternalServiceMock__MockingRulesAssignment_5_1_1)
-	{ after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__DelegateMock__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__0__Impl
-	rule__DelegateMock__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); }
-	'DelegateMock'
-	{ after(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__1__Impl
-	rule__DelegateMock__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); }
-	(rule__DelegateMock__NameAssignment_1)
-	{ after(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__2__Impl
-	rule__DelegateMock__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getForKeyword_2()); }
-	'for'
-	{ after(grammarAccess.getDelegateMockAccess().getForKeyword_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__3__Impl
-	rule__DelegateMock__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); }
-	(rule__DelegateMock__ServiceTaskReferenceAssignment_3)
-	{ after(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__4__Impl
-	rule__DelegateMock__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); }
-	'with'
-	{ after(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__5__Impl
-	rule__DelegateMock__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); }
-	'delegate'
-	{ after(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__6__Impl
-	rule__DelegateMock__Group__7
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); }
-	(rule__DelegateMock__DelegateClassAssignment_6)
-	{ after(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__7__Impl
-	rule__DelegateMock__Group__8
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__7__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getGroup_7()); }
-	(rule__DelegateMock__Group_7__0)?
-	{ after(grammarAccess.getDelegateMockAccess().getGroup_7()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__8
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group__8__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group__8__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-	RULE_DECLARATION_FINISHED
-	{ after(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__DelegateMock__Group_7__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group_7__0__Impl
-	rule__DelegateMock__Group_7__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); }
-	(rule__DelegateMock__ManualMocksAssignment_7_0)
-	{ after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group_7__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getGroup_7_1()); }
-	(rule__DelegateMock__Group_7_1__0)*
-	{ after(grammarAccess.getDelegateMockAccess().getGroup_7_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__DelegateMock__Group_7_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group_7_1__0__Impl
-	rule__DelegateMock__Group_7_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__DelegateMock__Group_7_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__DelegateMock__Group_7_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); }
-	(rule__DelegateMock__ManualMocksAssignment_7_1_1)
-	{ after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__MockingRule__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__0__Impl
-	rule__MockingRule__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); }
-	'with'
-	{ after(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__1__Impl
-	rule__MockingRule__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); }
-	'rule'
-	{ after(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__2__Impl
-	rule__MockingRule__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); }
-	RULE_ASSOCIATION
-	{ after(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__3__Impl
-	rule__MockingRule__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); }
-	'if'
-	{ after(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__4__Impl
-	rule__MockingRule__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__5__Impl
-	rule__MockingRule__Group__6
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getGroup_5()); }
-	(rule__MockingRule__Group_5__0)?
-	{ after(grammarAccess.getMockingRuleAccess().getGroup_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__6
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__6__Impl
-	rule__MockingRule__Group__7
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__6__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__7__Impl
-	rule__MockingRule__Group__8
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__7__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); }
-	'set'
-	{ after(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__8
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__8__Impl
-	rule__MockingRule__Group__9
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__8__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); }
-	RULE_LIST_OPEN
-	{ after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__9
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__9__Impl
-	rule__MockingRule__Group__10
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__9__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getGroup_9()); }
-	(rule__MockingRule__Group_9__0)?
-	{ after(grammarAccess.getMockingRuleAccess().getGroup_9()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__10
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group__10__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group__10__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
-	RULE_LIST_CLOSED
-	{ after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__MockingRule__Group_5__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_5__0__Impl
-	rule__MockingRule__Group_5__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); }
-	(rule__MockingRule__ComparisonsAssignment_5_0)
-	{ after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_5__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getGroup_5_1()); }
-	(rule__MockingRule__Group_5_1__0)*
-	{ after(grammarAccess.getMockingRuleAccess().getGroup_5_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__MockingRule__Group_5_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_5_1__0__Impl
-	rule__MockingRule__Group_5_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_5_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_5_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); }
-	(rule__MockingRule__ComparisonsAssignment_5_1_1)
-	{ after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__MockingRule__Group_9__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_9__0__Impl
-	rule__MockingRule__Group_9__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); }
-	(rule__MockingRule__VariablesAssignment_9_0)
-	{ after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_9__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getGroup_9_1()); }
-	(rule__MockingRule__Group_9_1__0)*
-	{ after(grammarAccess.getMockingRuleAccess().getGroup_9_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__MockingRule__Group_9_1__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_9_1__0__Impl
-	rule__MockingRule__Group_9_1__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9_1__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
-	RULE_SEPARATOR
-	{ after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9_1__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__MockingRule__Group_9_1__1__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__MockingRule__Group_9_1__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); }
-	(rule__MockingRule__VariablesAssignment_9_1_1)
-	{ after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__ManualMock__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__0__Impl
-	rule__ManualMock__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getWithKeyword_0()); }
-	'with'
-	{ after(grammarAccess.getManualMockAccess().getWithKeyword_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__1__Impl
-	rule__ManualMock__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getManualKeyword_1()); }
-	'manual'
-	{ after(grammarAccess.getManualMockAccess().getManualKeyword_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__2__Impl
-	rule__ManualMock__Group__3
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); }
-	(rule__ManualMock__ServiceNameAssignment_2)
-	{ after(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__3
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__3__Impl
-	rule__ManualMock__Group__4
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__3__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getByKeyword_3()); }
-	'by'
-	{ after(grammarAccess.getManualMockAccess().getByKeyword_3()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__4__Impl
-	rule__ManualMock__Group__5
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__4__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getSetterKeyword_4()); }
-	'setter'
-	{ after(grammarAccess.getManualMockAccess().getSetterKeyword_4()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__5
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__ManualMock__Group__5__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__ManualMock__Group__5__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getManualMockAccess().getSetterAssignment_5()); }
-	(rule__ManualMock__SetterAssignment_5)
-	{ after(grammarAccess.getManualMockAccess().getSetterAssignment_5()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__StringCompare__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringCompare__Group__0__Impl
-	rule__StringCompare__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringCompare__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); }
-	(rule__StringCompare__KeyAssignment_0)
-	{ after(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringCompare__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringCompare__Group__1__Impl
-	rule__StringCompare__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringCompare__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); }
-	(rule__StringCompare__CompareSymbolAssignment_1)
-	{ after(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringCompare__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__StringCompare__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StringCompare__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getStringCompareAccess().getValueAssignment_2()); }
-	(rule__StringCompare__ValueAssignment_2)
-	{ after(grammarAccess.getStringCompareAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__IntCompare__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntCompare__Group__0__Impl
-	rule__IntCompare__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntCompare__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); }
-	(rule__IntCompare__KeyAssignment_0)
-	{ after(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntCompare__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntCompare__Group__1__Impl
-	rule__IntCompare__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntCompare__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); }
-	(rule__IntCompare__CompareSymbolAssignment_1)
-	{ after(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntCompare__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__IntCompare__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__IntCompare__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getIntCompareAccess().getValueAssignment_2()); }
-	(rule__IntCompare__ValueAssignment_2)
-	{ after(grammarAccess.getIntCompareAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__BooleanCompare__Group__0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanCompare__Group__0__Impl
-	rule__BooleanCompare__Group__1
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanCompare__Group__0__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); }
-	(rule__BooleanCompare__KeyAssignment_0)
-	{ after(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanCompare__Group__1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanCompare__Group__1__Impl
-	rule__BooleanCompare__Group__2
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanCompare__Group__1__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); }
-	(rule__BooleanCompare__CompareSymbolAssignment_1)
-	{ after(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanCompare__Group__2
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	rule__BooleanCompare__Group__2__Impl
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BooleanCompare__Group__2__Impl
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-(
-	{ before(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); }
-	(rule__BooleanCompare__ValueAssignment_2)
-	{ after(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); }
-)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-
-rule__Model__DeclarationsAssignment
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); }
-		ruleDeclaration
-		{ after(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__NameAssignment_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__TestpackageAssignment_4
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__BpmnAssignment_7
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__KeyAssignment_10
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__DmnAssignment_11_4_0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__DmnAssignment_11_4_1_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__EmbeddedAssignment_12_4_0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__BPMNReference__RefAssignment
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); }
-		(
-			{ before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); }
-			RULE_ID
-			{ after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); }
-		)
-		{ after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__NameAssignment_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__HardcodedInputsAssignment_4_5_0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__StartVariablesAssignment_5_4_0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__StartFlowElement__StartVariablesAssignment_5_4_1_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__EndFlowElement__NameAssignment_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__UserTaskFlowElement__NameAssignment_1
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-	)
-;
-finally {
-	restoreStackSize(stackSize);
-}
-
-rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0
-	@init {
-		int stackSize = keepStackSize();
-	}
-:
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-	)
+	{ before(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); }
+	(rule__IntCompare__KeyAssignment_0)
+	{ after(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+rule__IntCompare__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-	)
+	rule__IntCompare__Group__1__Impl
+	rule__IntCompare__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0
+rule__IntCompare__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-	)
+(
+	{ before(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); }
+	(rule__IntCompare__CompareSymbolAssignment_1)
+	{ after(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1
+rule__IntCompare__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-	)
+	rule__IntCompare__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0
+rule__IntCompare__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
-	)
+(
+	{ before(grammarAccess.getIntCompareAccess().getValueAssignment_2()); }
+	(rule__IntCompare__ValueAssignment_2)
+	{ after(grammarAccess.getIntCompareAccess().getValueAssignment_2()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1
+
+rule__BooleanCompare__Group__0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
-	)
+	rule__BooleanCompare__Group__0__Impl
+	rule__BooleanCompare__Group__1
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__UserTaskFlowElement__LabelAssignment_7_3
+rule__BooleanCompare__Group__0__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
-	)
+(
+	{ before(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); }
+	(rule__BooleanCompare__KeyAssignment_0)
+	{ after(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__NameAssignment_1
+rule__BooleanCompare__Group__1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-	)
+	rule__BooleanCompare__Group__1__Impl
+	rule__BooleanCompare__Group__2
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0
+rule__BooleanCompare__Group__1__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-	)
+(
+	{ before(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); }
+	(rule__BooleanCompare__CompareSymbolAssignment_1)
+	{ after(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+rule__BooleanCompare__Group__2
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-	)
+	rule__BooleanCompare__Group__2__Impl
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0
+rule__BooleanCompare__Group__2__Impl
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
-	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-	)
+(
+	{ before(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); }
+	(rule__BooleanCompare__ValueAssignment_2)
+	{ after(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); }
+)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1
+
+rule__Model__DeclarationsAssignment
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
+		{ before(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); }
+		ruleDeclaration
+		{ after(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0
+rule__BPMNDiagram__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1
+rule__BPMNDiagram__TestpackageAssignment_4
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ManualTaskFlowElement__LabelAssignment_7_3
+rule__BPMNDiagram__BpmnAssignment_7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); }
 		RULE_STRING
-		{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
+		{ after(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__NameAssignment_1
+rule__BPMNDiagram__KeyAssignment_10
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0
+rule__BPMNDiagram__DmnAssignment_11_4_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+rule__BPMNDiagram__DmnAssignment_11_4_1_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0
+rule__BPMNDiagram__EmbeddedAssignment_12_4_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1
+rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); }
+		{ before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0
+rule__BPMNReference__RefAssignment
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
+		{ before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); }
+		(
+			{ before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); }
+			RULE_ID
+			{ after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); }
+		)
+		{ after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1
+rule__StartFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
+		{ before(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ScriptTaskFlowElement__LabelAssignment_7_3
+rule__StartFlowElement__InputVariablesAssignment_4_4_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); }
+		{ before(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); }
+		ruleVariableReference
+		{ after(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__NameAssignment_1
+rule__StartFlowElement__InputVariablesAssignment_4_4_1_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		{ before(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); }
+		ruleVariableReference
+		{ after(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__DelegateAssignment_7
+rule__EndFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); }
+		{ before(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3
+rule__UserTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
+		{ before(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__NameAssignment_1
+rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); }
+		ruleVariableReference
+		{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7
+rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); }
-		ruleExternalTopicReference
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); }
+		{ before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); }
+		ruleVariableReference
+		{ after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0
+rule__UserTaskFlowElement__LabelAssignment_5_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); }
+		{ before(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1
+rule__ManualTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); }
+		{ before(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0
+rule__ManualTaskFlowElement__LabelAssignment_4_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_0_0()); }
+		{ before(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1
+rule__ScriptTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0()); }
+		{ before(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0
+rule__ScriptTaskFlowElement__LabelAssignment_4_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0()); }
+		{ before(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1
+rule__DelegateServiceTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0()); }
+		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3
+rule__DelegateServiceTaskFlowElement__DelegateAssignment_7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_11_3_0()); }
+		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); }
 		RULE_STRING
-		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_11_3_0()); }
+		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__NameAssignment_1
+rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
-		RULE_ID
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		{ before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3
+rule__ExternalServiceTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); }
-		RULE_STRING
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); }
+		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0
+rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0()); }
-		ruleVariableDeclaration
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0()); }
+		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); }
+		ruleExternalTopicReference
+		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1
+rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0()); }
+		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); }
 		ruleVariableDeclaration
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0()); }
+		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0
+rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_0_0()); }
+		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); }
+		ruleVariableDeclaration
+		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1
+rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); }
+		{ before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_9_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_9_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0
+rule__BusinessRuleTaskFlowElement__NameAssignment_1
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0()); }
+		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
+		RULE_ID
+		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1
+rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0()); }
-		ruleVariableReference
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0()); }
+		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); }
+		RULE_STRING
+		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); }
 	)
 ;
 finally {
 	restoreStackSize(stackSize);
 }
 
-rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3
+rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
+		{ before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); }
 		RULE_STRING
-		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); }
+		{ after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); }
 	)
 ;
 finally {
@@ -17881,19 +13282,34 @@ finally {
 	restoreStackSize(stackSize);
 }
 
-rule__FlowElementReference__RefAssignment
+rule__FlowElementReference__RefAssignment_0
 	@init {
 		int stackSize = keepStackSize();
 	}
 :
 	(
-		{ before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0()); }
+		{ before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0_0()); }
 		(
-			{ before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_1()); }
+			{ before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_0_1()); }
 			RULE_ID
-			{ after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_1()); }
+			{ after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_0_1()); }
 		)
-		{ after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0()); }
+		{ after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0_0()); }
+	)
+;
+finally {
+	restoreStackSize(stackSize);
+}
+
+rule__FlowElementReference__FlagAssignment_1_1
+	@init {
+		int stackSize = keepStackSize();
+	}
+:
+	(
+		{ before(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0()); }
+		ruleFlag
+		{ after(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0()); }
 	)
 ;
 finally {
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.tokens b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.tokens
index e30e280830e7dc1debb72c1bc6de77c4212057f8..d16429d0c41882201306c0387b6b29894eb0283f 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.tokens
+++ b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSL.tokens
@@ -1,74 +1,73 @@
 '!='=19
 '<'=20
 '<='=22
-'='=78
+'='=77
 '=='=18
 '>'=21
 '>='=23
-'BPMNDiagram'=27
-'Boolean'=59
-'BusinessRuleTask'=50
-'DelegateMock'=81
-'EndEvent'=39
-'ExternalServiceMock'=79
-'ExternalTopic'=55
-'Flow'=68
-'FlowElement'=34
-'GREEN'=24
-'Gateway'=52
-'Integer'=58
-'Loop'=60
-'ManualTask'=45
-'RED'=26
-'ScriptTask'=46
-'SequenceFlow'=53
-'ServiceTask'=47
-'StartEvent'=35
-'String'=56
-'Test'=73
-'UserTask'=40
-'YELLOW'=25
-'and'=43
-'bpmn'=30
-'by'=63
-'check'=77
-'complexity'=66
-'delegate'=48
-'dmn'=32
-'elements'=70
-'embedded'=33
-'ends'=64
-'expression'=54
-'external'=49
+'BPMNDiagram'=28
+'Boolean'=58
+'BusinessRuleTask'=49
+'DelegateMock'=80
+'EndEvent'=38
+'ExternalServiceMock'=78
+'ExternalTopic'=54
+'Flow'=67
+'FlowElement'=35
+'GREEN'=25
+'Gateway'=51
+'Integer'=57
+'Loop'=59
+'ManualTask'=42
+'NONE'=24
+'RED'=27
+'ScriptTask'=43
+'SequenceFlow'=52
+'ServiceTask'=44
+'StartEvent'=36
+'String'=55
+'Test'=72
+'UserTask'=39
+'YELLOW'=26
+'and'=40
+'bpmn'=31
+'by'=62
+'check'=76
+'complexity'=65
+'delegate'=45
+'dmn'=33
+'elements'=69
+'embedded'=34
+'ends'=63
+'expression'=53
+'external'=46
 'false'=17
-'flag'=71
-'follows'=62
-'for'=69
-'hardcoded'=36
-'has'=65
-'if'=83
-'inputVariables'=41
-'inputs'=37
-'key'=31
-'label'=44
-'manual'=85
-'mocks'=75
-'outputVariables'=42
-'passed'=67
-'priority'=74
-'proposals'=57
-'resultVariable'=51
-'rule'=82
-'set'=84
-'setter'=86
-'startVariables'=38
-'starts'=61
-'testpackage'=29
-'topic'=80
+'flag'=70
+'follows'=61
+'for'=68
+'hardcoded'=47
+'has'=64
+'if'=82
+'inputVariables'=37
+'inputs'=48
+'key'=32
+'label'=41
+'manual'=84
+'mocks'=74
+'passed'=66
+'priority'=73
+'proposals'=56
+'resultVariable'=50
+'rule'=81
+'set'=83
+'setter'=85
+'starts'=60
+'testpackage'=30
+'topic'=79
 'true'=16
-'variables'=76
-'with'=28
-'without'=72
+'variables'=75
+'with'=29
+'without'=71
 RULE_ANY_OTHER=15
 RULE_ASSOCIATION=5
 RULE_DECLARATION_FINISHED=4
@@ -151,4 +150,3 @@ T__82=82
 T__83=83
 T__84=84
 T__85=85
-T__86=86
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLLexer.java b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLLexer.java
index 190f57ca797c0ca3f8aec2fe945fbe669ad48565..cb15cc6e9e2285a191b019166569951ff7f2a9ed 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLLexer.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLLexer.java
@@ -94,7 +94,6 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
     public static final int T__41=41;
     public static final int T__85=85;
     public static final int T__42=42;
-    public static final int T__86=86;
     public static final int T__43=43;
 
     // delegates
@@ -281,10 +280,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__24;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19:7: ( 'GREEN' )
-            // InternalTestgeneratorDSL.g:19:9: 'GREEN'
+            // InternalTestgeneratorDSL.g:19:7: ( 'NONE' )
+            // InternalTestgeneratorDSL.g:19:9: 'NONE'
             {
-            match("GREEN"); 
+            match("NONE"); 
 
 
             }
@@ -302,10 +301,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__25;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:20:7: ( 'YELLOW' )
-            // InternalTestgeneratorDSL.g:20:9: 'YELLOW'
+            // InternalTestgeneratorDSL.g:20:7: ( 'GREEN' )
+            // InternalTestgeneratorDSL.g:20:9: 'GREEN'
             {
-            match("YELLOW"); 
+            match("GREEN"); 
 
 
             }
@@ -323,10 +322,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__26;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:21:7: ( 'RED' )
-            // InternalTestgeneratorDSL.g:21:9: 'RED'
+            // InternalTestgeneratorDSL.g:21:7: ( 'YELLOW' )
+            // InternalTestgeneratorDSL.g:21:9: 'YELLOW'
             {
-            match("RED"); 
+            match("YELLOW"); 
 
 
             }
@@ -344,10 +343,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__27;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:22:7: ( 'BPMNDiagram' )
-            // InternalTestgeneratorDSL.g:22:9: 'BPMNDiagram'
+            // InternalTestgeneratorDSL.g:22:7: ( 'RED' )
+            // InternalTestgeneratorDSL.g:22:9: 'RED'
             {
-            match("BPMNDiagram"); 
+            match("RED"); 
 
 
             }
@@ -365,10 +364,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__28;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:23:7: ( 'with' )
-            // InternalTestgeneratorDSL.g:23:9: 'with'
+            // InternalTestgeneratorDSL.g:23:7: ( 'BPMNDiagram' )
+            // InternalTestgeneratorDSL.g:23:9: 'BPMNDiagram'
             {
-            match("with"); 
+            match("BPMNDiagram"); 
 
 
             }
@@ -386,10 +385,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__29;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:24:7: ( 'testpackage' )
-            // InternalTestgeneratorDSL.g:24:9: 'testpackage'
+            // InternalTestgeneratorDSL.g:24:7: ( 'with' )
+            // InternalTestgeneratorDSL.g:24:9: 'with'
             {
-            match("testpackage"); 
+            match("with"); 
 
 
             }
@@ -407,10 +406,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__30;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:25:7: ( 'bpmn' )
-            // InternalTestgeneratorDSL.g:25:9: 'bpmn'
+            // InternalTestgeneratorDSL.g:25:7: ( 'testpackage' )
+            // InternalTestgeneratorDSL.g:25:9: 'testpackage'
             {
-            match("bpmn"); 
+            match("testpackage"); 
 
 
             }
@@ -428,10 +427,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__31;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:26:7: ( 'key' )
-            // InternalTestgeneratorDSL.g:26:9: 'key'
+            // InternalTestgeneratorDSL.g:26:7: ( 'bpmn' )
+            // InternalTestgeneratorDSL.g:26:9: 'bpmn'
             {
-            match("key"); 
+            match("bpmn"); 
 
 
             }
@@ -449,10 +448,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__32;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:27:7: ( 'dmn' )
-            // InternalTestgeneratorDSL.g:27:9: 'dmn'
+            // InternalTestgeneratorDSL.g:27:7: ( 'key' )
+            // InternalTestgeneratorDSL.g:27:9: 'key'
             {
-            match("dmn"); 
+            match("key"); 
 
 
             }
@@ -470,10 +469,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__33;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:28:7: ( 'embedded' )
-            // InternalTestgeneratorDSL.g:28:9: 'embedded'
+            // InternalTestgeneratorDSL.g:28:7: ( 'dmn' )
+            // InternalTestgeneratorDSL.g:28:9: 'dmn'
             {
-            match("embedded"); 
+            match("dmn"); 
 
 
             }
@@ -491,10 +490,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__34;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:29:7: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:29:9: 'FlowElement'
+            // InternalTestgeneratorDSL.g:29:7: ( 'embedded' )
+            // InternalTestgeneratorDSL.g:29:9: 'embedded'
             {
-            match("FlowElement"); 
+            match("embedded"); 
 
 
             }
@@ -512,10 +511,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__35;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:30:7: ( 'StartEvent' )
-            // InternalTestgeneratorDSL.g:30:9: 'StartEvent'
+            // InternalTestgeneratorDSL.g:30:7: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:30:9: 'FlowElement'
             {
-            match("StartEvent"); 
+            match("FlowElement"); 
 
 
             }
@@ -533,10 +532,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__36;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:31:7: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:31:9: 'hardcoded'
+            // InternalTestgeneratorDSL.g:31:7: ( 'StartEvent' )
+            // InternalTestgeneratorDSL.g:31:9: 'StartEvent'
             {
-            match("hardcoded"); 
+            match("StartEvent"); 
 
 
             }
@@ -554,10 +553,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__37;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:32:7: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:32:9: 'inputs'
+            // InternalTestgeneratorDSL.g:32:7: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:32:9: 'inputVariables'
             {
-            match("inputs"); 
+            match("inputVariables"); 
 
 
             }
@@ -575,10 +574,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__38;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:33:7: ( 'startVariables' )
-            // InternalTestgeneratorDSL.g:33:9: 'startVariables'
+            // InternalTestgeneratorDSL.g:33:7: ( 'EndEvent' )
+            // InternalTestgeneratorDSL.g:33:9: 'EndEvent'
             {
-            match("startVariables"); 
+            match("EndEvent"); 
 
 
             }
@@ -596,10 +595,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__39;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:34:7: ( 'EndEvent' )
-            // InternalTestgeneratorDSL.g:34:9: 'EndEvent'
+            // InternalTestgeneratorDSL.g:34:7: ( 'UserTask' )
+            // InternalTestgeneratorDSL.g:34:9: 'UserTask'
             {
-            match("EndEvent"); 
+            match("UserTask"); 
 
 
             }
@@ -617,10 +616,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__40;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:35:7: ( 'UserTask' )
-            // InternalTestgeneratorDSL.g:35:9: 'UserTask'
+            // InternalTestgeneratorDSL.g:35:7: ( 'and' )
+            // InternalTestgeneratorDSL.g:35:9: 'and'
             {
-            match("UserTask"); 
+            match("and"); 
 
 
             }
@@ -638,10 +637,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__41;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:36:7: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:36:9: 'inputVariables'
+            // InternalTestgeneratorDSL.g:36:7: ( 'label' )
+            // InternalTestgeneratorDSL.g:36:9: 'label'
             {
-            match("inputVariables"); 
+            match("label"); 
 
 
             }
@@ -659,10 +658,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__42;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:37:7: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:37:9: 'outputVariables'
+            // InternalTestgeneratorDSL.g:37:7: ( 'ManualTask' )
+            // InternalTestgeneratorDSL.g:37:9: 'ManualTask'
             {
-            match("outputVariables"); 
+            match("ManualTask"); 
 
 
             }
@@ -680,10 +679,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__43;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:38:7: ( 'and' )
-            // InternalTestgeneratorDSL.g:38:9: 'and'
+            // InternalTestgeneratorDSL.g:38:7: ( 'ScriptTask' )
+            // InternalTestgeneratorDSL.g:38:9: 'ScriptTask'
             {
-            match("and"); 
+            match("ScriptTask"); 
 
 
             }
@@ -701,10 +700,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__44;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:39:7: ( 'label' )
-            // InternalTestgeneratorDSL.g:39:9: 'label'
+            // InternalTestgeneratorDSL.g:39:7: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:39:9: 'ServiceTask'
             {
-            match("label"); 
+            match("ServiceTask"); 
 
 
             }
@@ -722,10 +721,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__45;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:40:7: ( 'ManualTask' )
-            // InternalTestgeneratorDSL.g:40:9: 'ManualTask'
+            // InternalTestgeneratorDSL.g:40:7: ( 'delegate' )
+            // InternalTestgeneratorDSL.g:40:9: 'delegate'
             {
-            match("ManualTask"); 
+            match("delegate"); 
 
 
             }
@@ -743,10 +742,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__46;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:41:7: ( 'ScriptTask' )
-            // InternalTestgeneratorDSL.g:41:9: 'ScriptTask'
+            // InternalTestgeneratorDSL.g:41:7: ( 'external' )
+            // InternalTestgeneratorDSL.g:41:9: 'external'
             {
-            match("ScriptTask"); 
+            match("external"); 
 
 
             }
@@ -764,10 +763,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__47;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:42:7: ( 'ServiceTask' )
-            // InternalTestgeneratorDSL.g:42:9: 'ServiceTask'
+            // InternalTestgeneratorDSL.g:42:7: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:42:9: 'hardcoded'
             {
-            match("ServiceTask"); 
+            match("hardcoded"); 
 
 
             }
@@ -785,10 +784,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__48;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:43:7: ( 'delegate' )
-            // InternalTestgeneratorDSL.g:43:9: 'delegate'
+            // InternalTestgeneratorDSL.g:43:7: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:43:9: 'inputs'
             {
-            match("delegate"); 
+            match("inputs"); 
 
 
             }
@@ -806,10 +805,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__49;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:44:7: ( 'external' )
-            // InternalTestgeneratorDSL.g:44:9: 'external'
+            // InternalTestgeneratorDSL.g:44:7: ( 'BusinessRuleTask' )
+            // InternalTestgeneratorDSL.g:44:9: 'BusinessRuleTask'
             {
-            match("external"); 
+            match("BusinessRuleTask"); 
 
 
             }
@@ -827,10 +826,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__50;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:45:7: ( 'BusinessRuleTask' )
-            // InternalTestgeneratorDSL.g:45:9: 'BusinessRuleTask'
+            // InternalTestgeneratorDSL.g:45:7: ( 'resultVariable' )
+            // InternalTestgeneratorDSL.g:45:9: 'resultVariable'
             {
-            match("BusinessRuleTask"); 
+            match("resultVariable"); 
 
 
             }
@@ -848,10 +847,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__51;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:46:7: ( 'resultVariable' )
-            // InternalTestgeneratorDSL.g:46:9: 'resultVariable'
+            // InternalTestgeneratorDSL.g:46:7: ( 'Gateway' )
+            // InternalTestgeneratorDSL.g:46:9: 'Gateway'
             {
-            match("resultVariable"); 
+            match("Gateway"); 
 
 
             }
@@ -869,10 +868,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__52;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:47:7: ( 'Gateway' )
-            // InternalTestgeneratorDSL.g:47:9: 'Gateway'
+            // InternalTestgeneratorDSL.g:47:7: ( 'SequenceFlow' )
+            // InternalTestgeneratorDSL.g:47:9: 'SequenceFlow'
             {
-            match("Gateway"); 
+            match("SequenceFlow"); 
 
 
             }
@@ -890,10 +889,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__53;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:48:7: ( 'SequenceFlow' )
-            // InternalTestgeneratorDSL.g:48:9: 'SequenceFlow'
+            // InternalTestgeneratorDSL.g:48:7: ( 'expression' )
+            // InternalTestgeneratorDSL.g:48:9: 'expression'
             {
-            match("SequenceFlow"); 
+            match("expression"); 
 
 
             }
@@ -911,10 +910,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__54;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:49:7: ( 'expression' )
-            // InternalTestgeneratorDSL.g:49:9: 'expression'
+            // InternalTestgeneratorDSL.g:49:7: ( 'ExternalTopic' )
+            // InternalTestgeneratorDSL.g:49:9: 'ExternalTopic'
             {
-            match("expression"); 
+            match("ExternalTopic"); 
 
 
             }
@@ -932,10 +931,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__55;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:50:7: ( 'ExternalTopic' )
-            // InternalTestgeneratorDSL.g:50:9: 'ExternalTopic'
+            // InternalTestgeneratorDSL.g:50:7: ( 'String' )
+            // InternalTestgeneratorDSL.g:50:9: 'String'
             {
-            match("ExternalTopic"); 
+            match("String"); 
 
 
             }
@@ -953,10 +952,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__56;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:51:7: ( 'String' )
-            // InternalTestgeneratorDSL.g:51:9: 'String'
+            // InternalTestgeneratorDSL.g:51:7: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:51:9: 'proposals'
             {
-            match("String"); 
+            match("proposals"); 
 
 
             }
@@ -974,10 +973,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__57;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:52:7: ( 'proposals' )
-            // InternalTestgeneratorDSL.g:52:9: 'proposals'
+            // InternalTestgeneratorDSL.g:52:7: ( 'Integer' )
+            // InternalTestgeneratorDSL.g:52:9: 'Integer'
             {
-            match("proposals"); 
+            match("Integer"); 
 
 
             }
@@ -995,10 +994,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__58;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:53:7: ( 'Integer' )
-            // InternalTestgeneratorDSL.g:53:9: 'Integer'
+            // InternalTestgeneratorDSL.g:53:7: ( 'Boolean' )
+            // InternalTestgeneratorDSL.g:53:9: 'Boolean'
             {
-            match("Integer"); 
+            match("Boolean"); 
 
 
             }
@@ -1016,10 +1015,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__59;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:54:7: ( 'Boolean' )
-            // InternalTestgeneratorDSL.g:54:9: 'Boolean'
+            // InternalTestgeneratorDSL.g:54:7: ( 'Loop' )
+            // InternalTestgeneratorDSL.g:54:9: 'Loop'
             {
-            match("Boolean"); 
+            match("Loop"); 
 
 
             }
@@ -1037,10 +1036,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__60;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:55:7: ( 'Loop' )
-            // InternalTestgeneratorDSL.g:55:9: 'Loop'
+            // InternalTestgeneratorDSL.g:55:7: ( 'starts' )
+            // InternalTestgeneratorDSL.g:55:9: 'starts'
             {
-            match("Loop"); 
+            match("starts"); 
 
 
             }
@@ -1058,10 +1057,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__61;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:56:7: ( 'starts' )
-            // InternalTestgeneratorDSL.g:56:9: 'starts'
+            // InternalTestgeneratorDSL.g:56:7: ( 'follows' )
+            // InternalTestgeneratorDSL.g:56:9: 'follows'
             {
-            match("starts"); 
+            match("follows"); 
 
 
             }
@@ -1079,10 +1078,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__62;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:57:7: ( 'follows' )
-            // InternalTestgeneratorDSL.g:57:9: 'follows'
+            // InternalTestgeneratorDSL.g:57:7: ( 'by' )
+            // InternalTestgeneratorDSL.g:57:9: 'by'
             {
-            match("follows"); 
+            match("by"); 
 
 
             }
@@ -1100,10 +1099,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__63;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:58:7: ( 'by' )
-            // InternalTestgeneratorDSL.g:58:9: 'by'
+            // InternalTestgeneratorDSL.g:58:7: ( 'ends' )
+            // InternalTestgeneratorDSL.g:58:9: 'ends'
             {
-            match("by"); 
+            match("ends"); 
 
 
             }
@@ -1121,10 +1120,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__64;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:59:7: ( 'ends' )
-            // InternalTestgeneratorDSL.g:59:9: 'ends'
+            // InternalTestgeneratorDSL.g:59:7: ( 'has' )
+            // InternalTestgeneratorDSL.g:59:9: 'has'
             {
-            match("ends"); 
+            match("has"); 
 
 
             }
@@ -1142,10 +1141,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__65;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:60:7: ( 'has' )
-            // InternalTestgeneratorDSL.g:60:9: 'has'
+            // InternalTestgeneratorDSL.g:60:7: ( 'complexity' )
+            // InternalTestgeneratorDSL.g:60:9: 'complexity'
             {
-            match("has"); 
+            match("complexity"); 
 
 
             }
@@ -1163,10 +1162,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__66;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:61:7: ( 'complexity' )
-            // InternalTestgeneratorDSL.g:61:9: 'complexity'
+            // InternalTestgeneratorDSL.g:61:7: ( 'passed' )
+            // InternalTestgeneratorDSL.g:61:9: 'passed'
             {
-            match("complexity"); 
+            match("passed"); 
 
 
             }
@@ -1184,10 +1183,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__67;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:62:7: ( 'passed' )
-            // InternalTestgeneratorDSL.g:62:9: 'passed'
+            // InternalTestgeneratorDSL.g:62:7: ( 'Flow' )
+            // InternalTestgeneratorDSL.g:62:9: 'Flow'
             {
-            match("passed"); 
+            match("Flow"); 
 
 
             }
@@ -1205,10 +1204,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__68;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:63:7: ( 'Flow' )
-            // InternalTestgeneratorDSL.g:63:9: 'Flow'
+            // InternalTestgeneratorDSL.g:63:7: ( 'for' )
+            // InternalTestgeneratorDSL.g:63:9: 'for'
             {
-            match("Flow"); 
+            match("for"); 
 
 
             }
@@ -1226,10 +1225,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__69;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:64:7: ( 'for' )
-            // InternalTestgeneratorDSL.g:64:9: 'for'
+            // InternalTestgeneratorDSL.g:64:7: ( 'elements' )
+            // InternalTestgeneratorDSL.g:64:9: 'elements'
             {
-            match("for"); 
+            match("elements"); 
 
 
             }
@@ -1247,10 +1246,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__70;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:65:7: ( 'elements' )
-            // InternalTestgeneratorDSL.g:65:9: 'elements'
+            // InternalTestgeneratorDSL.g:65:7: ( 'flag' )
+            // InternalTestgeneratorDSL.g:65:9: 'flag'
             {
-            match("elements"); 
+            match("flag"); 
 
 
             }
@@ -1268,10 +1267,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__71;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:66:7: ( 'flag' )
-            // InternalTestgeneratorDSL.g:66:9: 'flag'
+            // InternalTestgeneratorDSL.g:66:7: ( 'without' )
+            // InternalTestgeneratorDSL.g:66:9: 'without'
             {
-            match("flag"); 
+            match("without"); 
 
 
             }
@@ -1289,10 +1288,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__72;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:67:7: ( 'without' )
-            // InternalTestgeneratorDSL.g:67:9: 'without'
+            // InternalTestgeneratorDSL.g:67:7: ( 'Test' )
+            // InternalTestgeneratorDSL.g:67:9: 'Test'
             {
-            match("without"); 
+            match("Test"); 
 
 
             }
@@ -1310,10 +1309,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__73;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:68:7: ( 'Test' )
-            // InternalTestgeneratorDSL.g:68:9: 'Test'
+            // InternalTestgeneratorDSL.g:68:7: ( 'priority' )
+            // InternalTestgeneratorDSL.g:68:9: 'priority'
             {
-            match("Test"); 
+            match("priority"); 
 
 
             }
@@ -1331,10 +1330,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__74;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:69:7: ( 'priority' )
-            // InternalTestgeneratorDSL.g:69:9: 'priority'
+            // InternalTestgeneratorDSL.g:69:7: ( 'mocks' )
+            // InternalTestgeneratorDSL.g:69:9: 'mocks'
             {
-            match("priority"); 
+            match("mocks"); 
 
 
             }
@@ -1352,10 +1351,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__75;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:70:7: ( 'mocks' )
-            // InternalTestgeneratorDSL.g:70:9: 'mocks'
+            // InternalTestgeneratorDSL.g:70:7: ( 'variables' )
+            // InternalTestgeneratorDSL.g:70:9: 'variables'
             {
-            match("mocks"); 
+            match("variables"); 
 
 
             }
@@ -1373,10 +1372,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__76;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:71:7: ( 'variables' )
-            // InternalTestgeneratorDSL.g:71:9: 'variables'
+            // InternalTestgeneratorDSL.g:71:7: ( 'check' )
+            // InternalTestgeneratorDSL.g:71:9: 'check'
             {
-            match("variables"); 
+            match("check"); 
 
 
             }
@@ -1394,11 +1393,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__77;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:72:7: ( 'check' )
-            // InternalTestgeneratorDSL.g:72:9: 'check'
+            // InternalTestgeneratorDSL.g:72:7: ( '=' )
+            // InternalTestgeneratorDSL.g:72:9: '='
             {
-            match("check"); 
-
+            match('='); 
 
             }
 
@@ -1415,10 +1413,11 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__78;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:73:7: ( '=' )
-            // InternalTestgeneratorDSL.g:73:9: '='
+            // InternalTestgeneratorDSL.g:73:7: ( 'ExternalServiceMock' )
+            // InternalTestgeneratorDSL.g:73:9: 'ExternalServiceMock'
             {
-            match('='); 
+            match("ExternalServiceMock"); 
+
 
             }
 
@@ -1435,10 +1434,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__79;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:74:7: ( 'ExternalServiceMock' )
-            // InternalTestgeneratorDSL.g:74:9: 'ExternalServiceMock'
+            // InternalTestgeneratorDSL.g:74:7: ( 'topic' )
+            // InternalTestgeneratorDSL.g:74:9: 'topic'
             {
-            match("ExternalServiceMock"); 
+            match("topic"); 
 
 
             }
@@ -1456,10 +1455,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__80;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:75:7: ( 'topic' )
-            // InternalTestgeneratorDSL.g:75:9: 'topic'
+            // InternalTestgeneratorDSL.g:75:7: ( 'DelegateMock' )
+            // InternalTestgeneratorDSL.g:75:9: 'DelegateMock'
             {
-            match("topic"); 
+            match("DelegateMock"); 
 
 
             }
@@ -1477,10 +1476,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__81;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:76:7: ( 'DelegateMock' )
-            // InternalTestgeneratorDSL.g:76:9: 'DelegateMock'
+            // InternalTestgeneratorDSL.g:76:7: ( 'rule' )
+            // InternalTestgeneratorDSL.g:76:9: 'rule'
             {
-            match("DelegateMock"); 
+            match("rule"); 
 
 
             }
@@ -1498,10 +1497,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__82;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:77:7: ( 'rule' )
-            // InternalTestgeneratorDSL.g:77:9: 'rule'
+            // InternalTestgeneratorDSL.g:77:7: ( 'if' )
+            // InternalTestgeneratorDSL.g:77:9: 'if'
             {
-            match("rule"); 
+            match("if"); 
 
 
             }
@@ -1519,10 +1518,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__83;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:78:7: ( 'if' )
-            // InternalTestgeneratorDSL.g:78:9: 'if'
+            // InternalTestgeneratorDSL.g:78:7: ( 'set' )
+            // InternalTestgeneratorDSL.g:78:9: 'set'
             {
-            match("if"); 
+            match("set"); 
 
 
             }
@@ -1540,10 +1539,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__84;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:79:7: ( 'set' )
-            // InternalTestgeneratorDSL.g:79:9: 'set'
+            // InternalTestgeneratorDSL.g:79:7: ( 'manual' )
+            // InternalTestgeneratorDSL.g:79:9: 'manual'
             {
-            match("set"); 
+            match("manual"); 
 
 
             }
@@ -1561,29 +1560,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__85;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:80:7: ( 'manual' )
-            // InternalTestgeneratorDSL.g:80:9: 'manual'
-            {
-            match("manual"); 
-
-
-            }
-
-            state.type = _type;
-            state.channel = _channel;
-        }
-        finally {
-        }
-    }
-    // $ANTLR end "T__85"
-
-    // $ANTLR start "T__86"
-    public final void mT__86() throws RecognitionException {
-        try {
-            int _type = T__86;
-            int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:81:7: ( 'setter' )
-            // InternalTestgeneratorDSL.g:81:9: 'setter'
+            // InternalTestgeneratorDSL.g:80:7: ( 'setter' )
+            // InternalTestgeneratorDSL.g:80:9: 'setter'
             {
             match("setter"); 
 
@@ -1596,15 +1574,15 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         finally {
         }
     }
-    // $ANTLR end "T__86"
+    // $ANTLR end "T__85"
 
     // $ANTLR start "RULE_LIST_OPEN"
     public final void mRULE_LIST_OPEN() throws RecognitionException {
         try {
             int _type = RULE_LIST_OPEN;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19231:16: ( '[' )
-            // InternalTestgeneratorDSL.g:19231:18: '['
+            // InternalTestgeneratorDSL.g:14647:16: ( '[' )
+            // InternalTestgeneratorDSL.g:14647:18: '['
             {
             match('['); 
 
@@ -1623,8 +1601,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_LIST_CLOSED;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19233:18: ( ']' )
-            // InternalTestgeneratorDSL.g:19233:20: ']'
+            // InternalTestgeneratorDSL.g:14649:18: ( ']' )
+            // InternalTestgeneratorDSL.g:14649:20: ']'
             {
             match(']'); 
 
@@ -1643,8 +1621,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ASSOCIATION;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19235:18: ( ':' )
-            // InternalTestgeneratorDSL.g:19235:20: ':'
+            // InternalTestgeneratorDSL.g:14651:18: ( ':' )
+            // InternalTestgeneratorDSL.g:14651:20: ':'
             {
             match(':'); 
 
@@ -1663,8 +1641,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_SEPARATOR;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19237:16: ( ',' )
-            // InternalTestgeneratorDSL.g:19237:18: ','
+            // InternalTestgeneratorDSL.g:14653:16: ( ',' )
+            // InternalTestgeneratorDSL.g:14653:18: ','
             {
             match(','); 
 
@@ -1683,8 +1661,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_DECLARATION_FINISHED;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19239:27: ( ';' )
-            // InternalTestgeneratorDSL.g:19239:29: ';'
+            // InternalTestgeneratorDSL.g:14655:27: ( ';' )
+            // InternalTestgeneratorDSL.g:14655:29: ';'
             {
             match(';'); 
 
@@ -1703,10 +1681,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ID;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19241:9: ( ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )* )
-            // InternalTestgeneratorDSL.g:19241:11: ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
+            // InternalTestgeneratorDSL.g:14657:9: ( ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )* )
+            // InternalTestgeneratorDSL.g:14657:11: ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
             {
-            // InternalTestgeneratorDSL.g:19241:11: ( '^' )?
+            // InternalTestgeneratorDSL.g:14657:11: ( '^' )?
             int alt1=2;
             int LA1_0 = input.LA(1);
 
@@ -1715,7 +1693,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt1) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:19241:11: '^'
+                    // InternalTestgeneratorDSL.g:14657:11: '^'
                     {
                     match('^'); 
 
@@ -1733,7 +1711,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 recover(mse);
                 throw mse;}
 
-            // InternalTestgeneratorDSL.g:19241:44: ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
+            // InternalTestgeneratorDSL.g:14657:44: ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
             loop2:
             do {
                 int alt2=2;
@@ -1782,10 +1760,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_INT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19243:10: ( ( '0' .. '9' )+ )
-            // InternalTestgeneratorDSL.g:19243:12: ( '0' .. '9' )+
+            // InternalTestgeneratorDSL.g:14659:10: ( ( '0' .. '9' )+ )
+            // InternalTestgeneratorDSL.g:14659:12: ( '0' .. '9' )+
             {
-            // InternalTestgeneratorDSL.g:19243:12: ( '0' .. '9' )+
+            // InternalTestgeneratorDSL.g:14659:12: ( '0' .. '9' )+
             int cnt3=0;
             loop3:
             do {
@@ -1799,7 +1777,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt3) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:19243:13: '0' .. '9'
+            	    // InternalTestgeneratorDSL.g:14659:13: '0' .. '9'
             	    {
             	    matchRange('0','9'); 
 
@@ -1831,10 +1809,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_STRING;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19245:13: ( ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' ) )
-            // InternalTestgeneratorDSL.g:19245:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
+            // InternalTestgeneratorDSL.g:14661:13: ( ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' ) )
+            // InternalTestgeneratorDSL.g:14661:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
             {
-            // InternalTestgeneratorDSL.g:19245:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
+            // InternalTestgeneratorDSL.g:14661:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
             int alt6=2;
             int LA6_0 = input.LA(1);
 
@@ -1852,10 +1830,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt6) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:19245:16: '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"'
+                    // InternalTestgeneratorDSL.g:14661:16: '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"'
                     {
                     match('\"'); 
-                    // InternalTestgeneratorDSL.g:19245:20: ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )*
+                    // InternalTestgeneratorDSL.g:14661:20: ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )*
                     loop4:
                     do {
                         int alt4=3;
@@ -1871,7 +1849,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         switch (alt4) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:19245:21: '\\\\' .
+                    	    // InternalTestgeneratorDSL.g:14661:21: '\\\\' .
                     	    {
                     	    match('\\'); 
                     	    matchAny(); 
@@ -1879,7 +1857,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     	    }
                     	    break;
                     	case 2 :
-                    	    // InternalTestgeneratorDSL.g:19245:28: ~ ( ( '\\\\' | '\"' ) )
+                    	    // InternalTestgeneratorDSL.g:14661:28: ~ ( ( '\\\\' | '\"' ) )
                     	    {
                     	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='!')||(input.LA(1)>='#' && input.LA(1)<='[')||(input.LA(1)>=']' && input.LA(1)<='\uFFFF') ) {
                     	        input.consume();
@@ -1904,10 +1882,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:19245:48: '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\''
+                    // InternalTestgeneratorDSL.g:14661:48: '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\''
                     {
                     match('\''); 
-                    // InternalTestgeneratorDSL.g:19245:53: ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )*
+                    // InternalTestgeneratorDSL.g:14661:53: ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )*
                     loop5:
                     do {
                         int alt5=3;
@@ -1923,7 +1901,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         switch (alt5) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:19245:54: '\\\\' .
+                    	    // InternalTestgeneratorDSL.g:14661:54: '\\\\' .
                     	    {
                     	    match('\\'); 
                     	    matchAny(); 
@@ -1931,7 +1909,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     	    }
                     	    break;
                     	case 2 :
-                    	    // InternalTestgeneratorDSL.g:19245:61: ~ ( ( '\\\\' | '\\'' ) )
+                    	    // InternalTestgeneratorDSL.g:14661:61: ~ ( ( '\\\\' | '\\'' ) )
                     	    {
                     	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='&')||(input.LA(1)>='(' && input.LA(1)<='[')||(input.LA(1)>=']' && input.LA(1)<='\uFFFF') ) {
                     	        input.consume();
@@ -1974,12 +1952,12 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ML_COMMENT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19247:17: ( '/*' ( options {greedy=false; } : . )* '*/' )
-            // InternalTestgeneratorDSL.g:19247:19: '/*' ( options {greedy=false; } : . )* '*/'
+            // InternalTestgeneratorDSL.g:14663:17: ( '/*' ( options {greedy=false; } : . )* '*/' )
+            // InternalTestgeneratorDSL.g:14663:19: '/*' ( options {greedy=false; } : . )* '*/'
             {
             match("/*"); 
 
-            // InternalTestgeneratorDSL.g:19247:24: ( options {greedy=false; } : . )*
+            // InternalTestgeneratorDSL.g:14663:24: ( options {greedy=false; } : . )*
             loop7:
             do {
                 int alt7=2;
@@ -2004,7 +1982,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt7) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:19247:52: .
+            	    // InternalTestgeneratorDSL.g:14663:52: .
             	    {
             	    matchAny(); 
 
@@ -2034,12 +2012,12 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_SL_COMMENT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19249:17: ( '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )? )
-            // InternalTestgeneratorDSL.g:19249:19: '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )?
+            // InternalTestgeneratorDSL.g:14665:17: ( '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )? )
+            // InternalTestgeneratorDSL.g:14665:19: '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )?
             {
             match("//"); 
 
-            // InternalTestgeneratorDSL.g:19249:24: (~ ( ( '\\n' | '\\r' ) ) )*
+            // InternalTestgeneratorDSL.g:14665:24: (~ ( ( '\\n' | '\\r' ) ) )*
             loop8:
             do {
                 int alt8=2;
@@ -2052,7 +2030,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt8) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:19249:24: ~ ( ( '\\n' | '\\r' ) )
+            	    // InternalTestgeneratorDSL.g:14665:24: ~ ( ( '\\n' | '\\r' ) )
             	    {
             	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='\t')||(input.LA(1)>='\u000B' && input.LA(1)<='\f')||(input.LA(1)>='\u000E' && input.LA(1)<='\uFFFF') ) {
             	        input.consume();
@@ -2072,7 +2050,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 }
             } while (true);
 
-            // InternalTestgeneratorDSL.g:19249:40: ( ( '\\r' )? '\\n' )?
+            // InternalTestgeneratorDSL.g:14665:40: ( ( '\\r' )? '\\n' )?
             int alt10=2;
             int LA10_0 = input.LA(1);
 
@@ -2081,9 +2059,9 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt10) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:19249:41: ( '\\r' )? '\\n'
+                    // InternalTestgeneratorDSL.g:14665:41: ( '\\r' )? '\\n'
                     {
-                    // InternalTestgeneratorDSL.g:19249:41: ( '\\r' )?
+                    // InternalTestgeneratorDSL.g:14665:41: ( '\\r' )?
                     int alt9=2;
                     int LA9_0 = input.LA(1);
 
@@ -2092,7 +2070,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     }
                     switch (alt9) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:19249:41: '\\r'
+                            // InternalTestgeneratorDSL.g:14665:41: '\\r'
                             {
                             match('\r'); 
 
@@ -2124,10 +2102,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_WS;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19251:9: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ )
-            // InternalTestgeneratorDSL.g:19251:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
+            // InternalTestgeneratorDSL.g:14667:9: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ )
+            // InternalTestgeneratorDSL.g:14667:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
             {
-            // InternalTestgeneratorDSL.g:19251:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
+            // InternalTestgeneratorDSL.g:14667:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
             int cnt11=0;
             loop11:
             do {
@@ -2181,8 +2159,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ANY_OTHER;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:19253:16: ( . )
-            // InternalTestgeneratorDSL.g:19253:18: .
+            // InternalTestgeneratorDSL.g:14669:16: ( . )
+            // InternalTestgeneratorDSL.g:14669:18: .
             {
             matchAny(); 
 
@@ -2197,8 +2175,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
     // $ANTLR end "RULE_ANY_OTHER"
 
     public void mTokens() throws RecognitionException {
-        // InternalTestgeneratorDSL.g:1:8: ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | T__86 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER )
-        int alt12=83;
+        // InternalTestgeneratorDSL.g:1:8: ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER )
+        int alt12=82;
         alt12 = dfa12.predict(input);
         switch (alt12) {
             case 1 :
@@ -2692,91 +2670,84 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 }
                 break;
             case 71 :
-                // InternalTestgeneratorDSL.g:1:430: T__86
-                {
-                mT__86(); 
-
-                }
-                break;
-            case 72 :
-                // InternalTestgeneratorDSL.g:1:436: RULE_LIST_OPEN
+                // InternalTestgeneratorDSL.g:1:430: RULE_LIST_OPEN
                 {
                 mRULE_LIST_OPEN(); 
 
                 }
                 break;
-            case 73 :
-                // InternalTestgeneratorDSL.g:1:451: RULE_LIST_CLOSED
+            case 72 :
+                // InternalTestgeneratorDSL.g:1:445: RULE_LIST_CLOSED
                 {
                 mRULE_LIST_CLOSED(); 
 
                 }
                 break;
-            case 74 :
-                // InternalTestgeneratorDSL.g:1:468: RULE_ASSOCIATION
+            case 73 :
+                // InternalTestgeneratorDSL.g:1:462: RULE_ASSOCIATION
                 {
                 mRULE_ASSOCIATION(); 
 
                 }
                 break;
-            case 75 :
-                // InternalTestgeneratorDSL.g:1:485: RULE_SEPARATOR
+            case 74 :
+                // InternalTestgeneratorDSL.g:1:479: RULE_SEPARATOR
                 {
                 mRULE_SEPARATOR(); 
 
                 }
                 break;
-            case 76 :
-                // InternalTestgeneratorDSL.g:1:500: RULE_DECLARATION_FINISHED
+            case 75 :
+                // InternalTestgeneratorDSL.g:1:494: RULE_DECLARATION_FINISHED
                 {
                 mRULE_DECLARATION_FINISHED(); 
 
                 }
                 break;
-            case 77 :
-                // InternalTestgeneratorDSL.g:1:526: RULE_ID
+            case 76 :
+                // InternalTestgeneratorDSL.g:1:520: RULE_ID
                 {
                 mRULE_ID(); 
 
                 }
                 break;
-            case 78 :
-                // InternalTestgeneratorDSL.g:1:534: RULE_INT
+            case 77 :
+                // InternalTestgeneratorDSL.g:1:528: RULE_INT
                 {
                 mRULE_INT(); 
 
                 }
                 break;
-            case 79 :
-                // InternalTestgeneratorDSL.g:1:543: RULE_STRING
+            case 78 :
+                // InternalTestgeneratorDSL.g:1:537: RULE_STRING
                 {
                 mRULE_STRING(); 
 
                 }
                 break;
-            case 80 :
-                // InternalTestgeneratorDSL.g:1:555: RULE_ML_COMMENT
+            case 79 :
+                // InternalTestgeneratorDSL.g:1:549: RULE_ML_COMMENT
                 {
                 mRULE_ML_COMMENT(); 
 
                 }
                 break;
-            case 81 :
-                // InternalTestgeneratorDSL.g:1:571: RULE_SL_COMMENT
+            case 80 :
+                // InternalTestgeneratorDSL.g:1:565: RULE_SL_COMMENT
                 {
                 mRULE_SL_COMMENT(); 
 
                 }
                 break;
-            case 82 :
-                // InternalTestgeneratorDSL.g:1:587: RULE_WS
+            case 81 :
+                // InternalTestgeneratorDSL.g:1:581: RULE_WS
                 {
                 mRULE_WS(); 
 
                 }
                 break;
-            case 83 :
-                // InternalTestgeneratorDSL.g:1:595: RULE_ANY_OTHER
+            case 82 :
+                // InternalTestgeneratorDSL.g:1:589: RULE_ANY_OTHER
                 {
                 mRULE_ANY_OTHER(); 
 
@@ -2790,49 +2761,49 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
     protected DFA12 dfa12 = new DFA12(this);
     static final String DFA12_eotS =
-        "\1\uffff\2\64\1\71\1\60\1\74\1\76\35\64\5\uffff\1\60\2\uffff\3\60\2\uffff\3\64\1\uffff\3\64\7\uffff\11\64\1\u0087\15\64\1\u0099\26\64\12\uffff\5\64\1\u00b6\4\64\1\u00bb\5\64\1\uffff\1\u00c1\1\u00c2\15\64\1\u00d0\1\64\1\uffff\1\64\1\u00d4\4\64\1\u00d9\20\64\1\u00ea\4\64\1\uffff\1\u00ef\3\64\1\uffff\3\64\1\u00f7\1\u00f8\2\uffff\4\64\1\u00fd\1\64\1\u0100\6\64\1\uffff\3\64\1\uffff\4\64\1\uffff\3\64\1\u0111\4\64\1\u0116\2\64\1\u0119\4\64\1\uffff\1\64\1\u011f\1\u0120\1\64\1\uffff\1\u0122\6\64\2\uffff\4\64\1\uffff\2\64\1\uffff\15\64\1\u013e\2\64\1\uffff\4\64\1\uffff\1\64\1\u0146\1\uffff\1\u0147\4\64\2\uffff\1\64\1\uffff\1\64\1\u014e\13\64\1\u015a\4\64\1\u015f\2\64\1\u0162\1\u0163\4\64\1\uffff\4\64\1\u016c\2\64\2\uffff\1\u016f\3\64\1\u0173\1\u0174\1\uffff\2\64\1\u0177\1\u0178\7\64\1\uffff\4\64\1\uffff\2\64\2\uffff\10\64\1\uffff\1\u018e\1\64\1\uffff\3\64\2\uffff\2\64\2\uffff\1\u0195\1\u0196\1\u0197\1\64\1\u0199\10\64\1\u01a2\1\64\1\u01a5\4\64\1\u01aa\1\uffff\6\64\3\uffff\1\64\1\uffff\5\64\1\u01b7\2\64\1\uffff\2\64\1\uffff\3\64\1\u01bf\1\uffff\1\64\1\u01c1\4\64\1\u01c6\1\64\1\u01c8\1\u01c9\2\64\1\uffff\5\64\1\u01d1\1\64\1\uffff\1\u01d3\1\uffff\1\64\1\u01d5\1\u01d6\1\64\1\uffff\1\u01d8\2\uffff\1\u01d9\6\64\1\uffff\1\64\1\uffff\1\64\2\uffff\1\64\2\uffff\1\u01e3\6\64\1\u01ea\1\64\1\uffff\2\64\1\u01ee\3\64\1\uffff\1\64\1\u01f3\1\u01f4\1\uffff\2\64\1\u01f7\1\64\2\uffff\1\64\1\u01fa\1\uffff\1\u01fb\1\64\2\uffff\2\64\1\u01ff\1\uffff";
+        "\1\uffff\2\64\1\71\1\60\1\74\1\76\35\64\5\uffff\1\60\2\uffff\3\60\2\uffff\3\64\1\uffff\3\64\7\uffff\12\64\1\u0088\14\64\1\u0098\26\64\12\uffff\5\64\1\u00b6\5\64\1\u00bc\5\64\1\uffff\1\u00c2\1\u00c3\15\64\1\uffff\3\64\1\u00d4\3\64\1\u00d8\10\64\1\u00e2\7\64\1\u00ea\4\64\1\uffff\1\u00ef\1\u00f0\3\64\1\uffff\3\64\1\u00f8\1\u00f9\2\uffff\4\64\1\u00fe\1\64\1\u0101\11\64\1\uffff\3\64\1\uffff\1\64\1\u010f\4\64\1\u0114\2\64\1\uffff\2\64\1\u0119\4\64\1\uffff\1\64\1\u011f\1\u0120\1\64\2\uffff\1\u0122\6\64\2\uffff\4\64\1\uffff\2\64\1\uffff\11\64\1\u0139\3\64\1\uffff\4\64\1\uffff\3\64\1\u0144\1\uffff\1\u0145\4\64\2\uffff\1\64\1\uffff\1\64\1\u014c\13\64\1\u0158\4\64\1\u015d\3\64\1\uffff\5\64\1\u0166\1\64\1\u0168\1\u0169\1\64\2\uffff\1\u016b\3\64\1\u016f\1\u0170\1\uffff\2\64\1\u0173\1\u0174\7\64\1\uffff\4\64\1\uffff\10\64\1\uffff\1\u0188\2\uffff\1\64\1\uffff\3\64\2\uffff\2\64\2\uffff\1\u018f\1\u0190\1\u0191\1\64\1\u0193\6\64\1\u019a\1\64\1\u019d\4\64\1\u01a2\1\uffff\6\64\3\uffff\1\64\1\uffff\6\64\1\uffff\2\64\1\uffff\1\64\1\u01b3\1\64\1\u01b5\1\uffff\1\64\1\u01b7\4\64\1\u01bc\1\64\1\u01be\1\u01bf\5\64\1\u01c5\1\uffff\1\64\1\uffff\1\u01c7\1\uffff\1\64\1\u01c9\1\u01ca\1\64\1\uffff\1\u01cc\2\uffff\1\u01cd\4\64\1\uffff\1\64\1\uffff\1\64\2\uffff\1\64\2\uffff\1\u01d5\4\64\1\u01da\1\64\1\uffff\1\64\1\u01dd\2\64\1\uffff\1\64\1\u01e1\1\uffff\1\64\1\u01e3\1\64\1\uffff\1\64\1\uffff\1\u01e6\1\64\1\uffff\2\64\1\u01ea\1\uffff";
     static final String DFA12_eofS =
-        "\u0200\uffff";
+        "\u01eb\uffff";
     static final String DFA12_minS =
-        "\1\0\1\145\1\141\4\75\1\122\2\105\1\120\1\151\1\160\2\145\2\154\1\143\1\141\1\146\1\145\1\156\1\163\1\165\1\156\2\141\1\145\1\141\1\156\1\157\1\150\1\145\2\141\1\145\5\uffff\1\55\2\uffff\2\0\1\52\2\uffff\1\165\1\163\1\160\1\uffff\2\154\1\141\7\uffff\1\105\1\164\1\114\1\104\1\115\1\163\1\157\1\164\1\155\1\55\1\171\1\156\1\154\1\142\1\160\1\144\1\145\1\157\1\141\1\162\1\161\1\162\1\160\1\55\1\141\1\164\1\144\1\164\1\145\1\164\1\144\1\142\1\156\1\163\1\154\1\151\1\163\1\164\1\157\1\155\1\145\1\163\1\143\1\156\1\162\1\154\12\uffff\1\145\1\164\1\151\1\163\1\154\1\55\1\147\1\105\1\145\1\114\1\55\1\116\1\151\1\154\1\150\1\156\1\uffff\2\55\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\1\165\1\144\1\55\1\165\1\uffff\1\162\1\55\1\105\1\145\1\162\1\160\1\55\1\145\2\165\1\145\1\160\1\157\1\163\1\145\2\160\1\143\1\164\1\153\1\165\1\151\1\145\1\55\1\160\1\143\1\145\1\157\1\uffff\1\55\1\116\1\167\1\117\1\uffff\1\104\1\156\1\145\2\55\2\uffff\1\147\1\144\1\162\1\145\1\55\1\145\1\55\1\164\1\156\1\160\1\151\1\145\1\143\1\uffff\2\164\1\145\1\uffff\1\166\1\162\1\124\1\165\1\uffff\1\154\1\141\1\154\1\55\1\157\1\162\1\145\1\147\1\55\1\154\1\153\1\55\1\163\2\141\1\147\1\uffff\1\141\2\55\1\167\1\uffff\1\55\1\141\1\127\1\151\1\145\1\141\1\165\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\157\2\126\1\162\1\145\1\156\1\141\1\164\1\55\1\154\1\164\1\uffff\1\163\1\151\1\144\1\145\1\uffff\1\145\1\55\1\uffff\1\55\1\154\1\142\1\141\1\143\2\uffff\1\163\1\uffff\1\171\1\55\1\141\1\163\1\156\2\164\1\145\1\141\1\163\1\164\1\145\1\166\1\55\1\124\1\145\1\143\1\144\1\55\2\141\2\55\1\156\1\141\1\163\1\126\1\uffff\1\124\1\126\1\141\1\164\1\55\1\162\1\170\2\uffff\1\55\1\154\1\164\1\153\2\55\1\uffff\1\147\1\163\2\55\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\2\145\1\uffff\2\162\2\uffff\1\164\1\154\1\153\3\141\1\154\1\171\1\uffff\1\55\1\151\1\uffff\2\145\1\141\2\uffff\1\162\1\122\2\uffff\3\55\1\157\1\55\1\145\1\156\1\163\1\141\1\106\1\144\2\151\1\55\1\123\1\55\1\162\1\163\1\162\1\163\1\55\1\uffff\1\164\1\163\1\115\1\147\1\141\1\165\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\55\2\141\1\uffff\1\157\1\145\1\uffff\1\151\1\153\1\151\1\55\1\uffff\1\171\1\55\1\157\1\145\1\155\1\154\1\55\1\164\2\55\1\153\1\157\1\uffff\2\142\1\160\1\162\1\141\1\55\1\141\1\uffff\1\55\1\uffff\1\143\2\55\1\145\1\uffff\1\55\2\uffff\1\55\1\167\2\154\1\151\1\166\1\142\1\uffff\1\142\1\uffff\1\153\2\uffff\1\124\2\uffff\1\55\2\145\1\143\1\151\2\154\1\55\1\141\1\uffff\2\163\1\55\1\143\2\145\1\uffff\1\163\2\55\1\uffff\1\145\1\163\1\55\1\153\2\uffff\1\115\1\55\1\uffff\1\55\1\157\2\uffff\1\143\1\153\1\55\1\uffff";
+        "\1\0\1\145\1\141\4\75\1\117\1\122\2\105\1\120\1\151\1\160\2\145\2\154\1\143\1\146\1\156\1\163\1\156\3\141\1\145\1\141\1\156\1\157\1\145\1\150\1\145\2\141\1\145\5\uffff\1\55\2\uffff\2\0\1\52\2\uffff\1\165\1\163\1\160\1\uffff\2\154\1\141\7\uffff\1\116\1\105\1\164\1\114\1\104\1\115\1\163\1\157\1\164\1\155\1\55\1\171\1\156\1\154\1\142\1\160\1\144\1\145\1\157\1\141\1\162\1\161\1\160\1\55\1\144\1\164\1\145\1\144\1\142\1\156\1\162\1\163\1\154\1\151\1\163\1\164\1\157\1\141\1\164\1\155\1\145\1\163\1\143\1\156\1\162\1\154\12\uffff\1\145\1\164\1\151\1\163\1\154\1\55\1\147\2\105\1\145\1\114\1\55\1\116\1\151\1\154\1\150\1\156\1\uffff\2\55\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\2\165\1\uffff\1\105\1\145\1\162\1\55\1\145\1\165\1\144\1\55\1\165\1\145\1\160\1\157\1\163\1\145\1\160\1\162\1\55\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\55\1\160\1\143\1\145\1\157\1\uffff\2\55\1\116\1\167\1\117\1\uffff\1\104\1\156\1\145\2\55\2\uffff\1\147\1\144\1\162\1\145\1\55\1\145\1\55\1\164\1\156\1\160\1\151\1\145\1\164\1\166\1\162\1\124\1\uffff\1\154\1\141\1\143\1\uffff\1\154\1\55\1\157\1\162\1\145\1\147\1\55\1\164\1\145\1\uffff\1\154\1\153\1\55\1\163\2\141\1\147\1\uffff\1\141\2\55\1\167\2\uffff\1\55\1\141\1\127\1\151\1\145\1\141\1\165\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\126\1\145\1\156\1\141\1\55\1\154\1\157\1\164\1\uffff\1\163\1\151\1\144\1\145\1\uffff\1\163\1\162\1\145\1\55\1\uffff\1\55\1\154\1\142\1\141\1\143\2\uffff\1\163\1\uffff\1\171\1\55\1\141\1\163\1\156\2\164\1\145\1\141\1\163\1\164\1\145\1\166\1\55\1\124\1\145\1\143\1\141\1\55\1\156\1\141\1\163\1\uffff\1\124\1\144\1\126\1\141\1\164\1\55\1\162\2\55\1\170\2\uffff\1\55\1\154\1\164\1\153\2\55\1\uffff\1\147\1\163\2\55\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\1\145\1\162\1\uffff\1\164\1\154\1\153\1\141\1\145\1\141\1\154\1\171\1\uffff\1\55\2\uffff\1\151\1\uffff\2\145\1\141\2\uffff\1\162\1\122\2\uffff\3\55\1\157\1\55\1\145\1\156\1\163\1\141\1\106\1\151\1\55\1\123\1\55\1\163\1\144\1\162\1\163\1\55\1\uffff\1\164\1\163\1\115\1\147\1\141\1\165\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\141\1\uffff\1\157\1\145\1\uffff\1\153\1\55\1\151\1\55\1\uffff\1\171\1\55\1\157\1\145\1\155\1\154\1\55\1\164\2\55\1\153\1\157\1\142\1\160\1\162\1\55\1\uffff\1\141\1\uffff\1\55\1\uffff\1\143\2\55\1\145\1\uffff\1\55\2\uffff\1\55\1\167\1\154\1\151\1\166\1\uffff\1\142\1\uffff\1\153\2\uffff\1\124\2\uffff\1\55\1\145\1\143\1\151\1\154\1\55\1\141\1\uffff\1\163\1\55\1\143\1\145\1\uffff\1\163\1\55\1\uffff\1\145\1\55\1\153\1\uffff\1\115\1\uffff\1\55\1\157\1\uffff\1\143\1\153\1\55\1\uffff";
     static final String DFA12_maxS =
-        "\1\uffff\1\162\1\157\4\75\1\141\2\105\1\165\1\151\1\171\1\145\1\155\1\170\1\154\1\164\1\141\1\156\1\164\1\170\1\163\1\165\1\156\2\141\1\165\1\162\1\156\2\157\1\145\1\157\1\141\1\145\5\uffff\1\172\2\uffff\2\uffff\1\57\2\uffff\1\165\1\163\1\160\1\uffff\1\154\1\162\1\141\7\uffff\1\105\1\164\1\114\1\104\1\115\1\163\1\157\1\164\1\155\1\172\1\171\1\156\1\154\1\142\1\164\1\144\1\145\1\157\3\162\1\163\1\160\1\172\1\141\1\164\1\144\1\164\1\145\1\164\1\144\1\142\1\156\1\163\1\154\1\157\1\163\1\164\1\157\1\155\1\145\1\163\1\143\1\156\1\162\1\154\12\uffff\1\145\1\164\1\151\1\163\1\154\1\172\1\147\1\105\1\145\1\114\1\172\1\116\1\151\1\154\1\150\1\156\1\uffff\2\172\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\1\165\1\144\1\172\1\165\1\uffff\1\162\1\172\1\105\1\145\1\162\1\160\1\172\1\145\2\165\1\145\1\160\1\157\1\163\1\145\2\160\1\143\1\164\1\153\1\165\1\151\1\145\1\172\1\160\1\143\1\145\1\157\1\uffff\1\172\1\116\1\167\1\117\1\uffff\1\104\1\156\1\145\2\172\2\uffff\1\147\1\144\1\162\1\145\1\172\1\145\1\172\1\164\1\156\1\160\1\151\1\145\1\143\1\uffff\2\164\1\145\1\uffff\1\166\1\162\1\124\1\165\1\uffff\1\154\1\141\1\154\1\172\1\157\1\162\1\145\1\147\1\172\1\154\1\153\1\172\1\163\2\141\1\147\1\uffff\1\141\2\172\1\167\1\uffff\1\172\1\141\1\127\1\151\1\145\1\141\1\165\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\157\2\163\1\162\1\145\1\156\1\141\1\164\1\172\1\154\1\164\1\uffff\1\163\1\151\1\144\1\145\1\uffff\1\145\1\172\1\uffff\1\172\1\154\1\142\1\141\1\143\2\uffff\1\163\1\uffff\1\171\1\172\1\141\1\163\1\156\2\164\1\145\1\141\1\163\1\164\1\145\1\166\1\172\1\124\1\145\1\143\1\144\1\172\2\141\2\172\1\156\1\141\1\163\1\126\1\uffff\1\124\1\126\1\141\1\164\1\172\1\162\1\170\2\uffff\1\172\1\154\1\164\1\153\2\172\1\uffff\1\147\1\163\2\172\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\2\145\1\uffff\2\162\2\uffff\1\164\1\154\1\153\3\141\1\154\1\171\1\uffff\1\172\1\151\1\uffff\2\145\1\141\2\uffff\1\162\1\122\2\uffff\3\172\1\157\1\172\1\145\1\156\1\163\1\141\1\106\1\144\2\151\1\172\1\124\1\172\1\162\1\163\1\162\1\163\1\172\1\uffff\1\164\1\163\1\115\1\147\1\141\1\165\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\172\2\141\1\uffff\1\157\1\145\1\uffff\1\151\1\153\1\151\1\172\1\uffff\1\171\1\172\1\157\1\145\1\155\1\154\1\172\1\164\2\172\1\153\1\157\1\uffff\2\142\1\160\1\162\1\141\1\172\1\141\1\uffff\1\172\1\uffff\1\143\2\172\1\145\1\uffff\1\172\2\uffff\1\172\1\167\2\154\1\151\1\166\1\142\1\uffff\1\142\1\uffff\1\153\2\uffff\1\124\2\uffff\1\172\2\145\1\143\1\151\2\154\1\172\1\141\1\uffff\2\163\1\172\1\143\2\145\1\uffff\1\163\2\172\1\uffff\1\145\1\163\1\172\1\153\2\uffff\1\115\1\172\1\uffff\1\172\1\157\2\uffff\1\143\1\153\1\172\1\uffff";
+        "\1\uffff\1\162\1\157\4\75\1\117\1\141\2\105\1\165\1\151\1\171\1\145\1\155\1\170\1\154\1\164\1\156\1\170\1\163\1\156\3\141\1\165\1\162\1\156\1\157\1\164\1\157\1\145\1\157\1\141\1\145\5\uffff\1\172\2\uffff\2\uffff\1\57\2\uffff\1\165\1\163\1\160\1\uffff\1\154\1\162\1\141\7\uffff\1\116\1\105\1\164\1\114\1\104\1\115\1\163\1\157\1\164\1\155\1\172\1\171\1\156\1\154\1\142\1\164\1\144\1\145\1\157\3\162\1\160\1\172\1\144\1\164\1\145\1\144\1\142\1\156\2\163\1\154\1\157\1\163\1\164\1\157\1\141\1\164\1\155\1\145\1\163\1\143\1\156\1\162\1\154\12\uffff\1\145\1\164\1\151\1\163\1\154\1\172\1\147\2\105\1\145\1\114\1\172\1\116\1\151\1\154\1\150\1\156\1\uffff\2\172\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\2\165\1\uffff\1\105\1\145\1\162\1\172\1\145\1\165\1\144\1\172\1\165\1\145\1\160\1\157\1\163\1\145\1\160\1\162\1\172\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\172\1\160\1\143\1\145\1\157\1\uffff\2\172\1\116\1\167\1\117\1\uffff\1\104\1\156\1\145\2\172\2\uffff\1\147\1\144\1\162\1\145\1\172\1\145\1\172\1\164\1\156\1\160\1\151\1\145\1\164\1\166\1\162\1\124\1\uffff\1\154\1\141\1\143\1\uffff\1\154\1\172\1\157\1\162\1\145\1\147\1\172\1\164\1\145\1\uffff\1\154\1\153\1\172\1\163\2\141\1\147\1\uffff\1\141\2\172\1\167\2\uffff\1\172\1\141\1\127\1\151\1\145\1\141\1\165\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\163\1\145\1\156\1\141\1\172\1\154\1\157\1\164\1\uffff\1\163\1\151\1\144\1\145\1\uffff\1\163\1\162\1\145\1\172\1\uffff\1\172\1\154\1\142\1\141\1\143\2\uffff\1\163\1\uffff\1\171\1\172\1\141\1\163\1\156\2\164\1\145\1\141\1\163\1\164\1\145\1\166\1\172\1\124\1\145\1\143\1\141\1\172\1\156\1\141\1\163\1\uffff\1\124\1\144\1\126\1\141\1\164\1\172\1\162\2\172\1\170\2\uffff\1\172\1\154\1\164\1\153\2\172\1\uffff\1\147\1\163\2\172\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\1\145\1\162\1\uffff\1\164\1\154\1\153\1\141\1\145\1\141\1\154\1\171\1\uffff\1\172\2\uffff\1\151\1\uffff\2\145\1\141\2\uffff\1\162\1\122\2\uffff\3\172\1\157\1\172\1\145\1\156\1\163\1\141\1\106\1\151\1\172\1\124\1\172\1\163\1\144\1\162\1\163\1\172\1\uffff\1\164\1\163\1\115\1\147\1\141\1\165\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\141\1\uffff\1\157\1\145\1\uffff\1\153\1\172\1\151\1\172\1\uffff\1\171\1\172\1\157\1\145\1\155\1\154\1\172\1\164\2\172\1\153\1\157\1\142\1\160\1\162\1\172\1\uffff\1\141\1\uffff\1\172\1\uffff\1\143\2\172\1\145\1\uffff\1\172\2\uffff\1\172\1\167\1\154\1\151\1\166\1\uffff\1\142\1\uffff\1\153\2\uffff\1\124\2\uffff\1\172\1\145\1\143\1\151\1\154\1\172\1\141\1\uffff\1\163\1\172\1\143\1\145\1\uffff\1\163\1\172\1\uffff\1\145\1\172\1\153\1\uffff\1\115\1\uffff\1\172\1\157\1\uffff\1\143\1\153\1\172\1\uffff";
     static final String DFA12_acceptS =
-        "\44\uffff\1\110\1\111\1\112\1\113\1\114\1\uffff\1\115\1\116\3\uffff\1\122\1\123\3\uffff\1\115\3\uffff\1\3\1\77\1\4\1\7\1\5\1\10\1\6\56\uffff\1\110\1\111\1\112\1\113\1\114\1\116\1\117\1\120\1\121\1\122\20\uffff\1\60\21\uffff\1\104\34\uffff\1\66\4\uffff\1\13\5\uffff\1\20\1\21\15\uffff\1\62\3\uffff\1\105\4\uffff\1\34\20\uffff\1\1\4\uffff\1\70\7\uffff\1\15\1\17\4\uffff\1\61\2\uffff\1\65\20\uffff\1\103\4\uffff\1\55\2\uffff\1\72\5\uffff\1\101\1\2\1\uffff\1\11\33\uffff\1\35\7\uffff\1\76\1\74\6\uffff\1\12\13\uffff\1\51\4\uffff\1\26\2\uffff\1\56\1\107\10\uffff\1\64\2\uffff\1\106\3\uffff\1\57\1\45\2\uffff\1\54\1\71\25\uffff\1\53\6\uffff\1\41\1\22\1\42\1\uffff\1\67\10\uffff\1\30\2\uffff\1\31\4\uffff\1\73\14\uffff\1\25\7\uffff\1\52\1\uffff\1\75\4\uffff\1\47\1\uffff\1\24\1\37\7\uffff\1\36\1\uffff\1\63\1\uffff\1\16\1\14\1\uffff\1\23\1\40\11\uffff\1\46\6\uffff\1\102\3\uffff\1\50\4\uffff\1\32\1\27\2\uffff\1\44\2\uffff\1\33\1\43\3\uffff\1\100";
+        "\44\uffff\1\107\1\110\1\111\1\112\1\113\1\uffff\1\114\1\115\3\uffff\1\121\1\122\3\uffff\1\114\3\uffff\1\3\1\76\1\4\1\7\1\5\1\10\1\6\56\uffff\1\107\1\110\1\111\1\112\1\113\1\115\1\116\1\117\1\120\1\121\21\uffff\1\57\17\uffff\1\103\35\uffff\1\65\5\uffff\1\14\5\uffff\1\21\1\22\20\uffff\1\31\3\uffff\1\61\11\uffff\1\104\7\uffff\1\1\4\uffff\1\67\1\11\7\uffff\1\16\1\20\4\uffff\1\60\2\uffff\1\64\15\uffff\1\102\4\uffff\1\54\4\uffff\1\71\5\uffff\1\100\1\2\1\uffff\1\12\26\uffff\1\32\12\uffff\1\75\1\73\6\uffff\1\13\13\uffff\1\50\4\uffff\1\41\10\uffff\1\63\1\uffff\1\55\1\106\1\uffff\1\105\3\uffff\1\56\1\44\2\uffff\1\53\1\70\23\uffff\1\52\6\uffff\1\36\1\23\1\37\1\uffff\1\66\6\uffff\1\27\2\uffff\1\30\4\uffff\1\72\20\uffff\1\40\1\uffff\1\51\1\uffff\1\74\4\uffff\1\46\1\uffff\1\25\1\34\5\uffff\1\33\1\uffff\1\62\1\uffff\1\17\1\15\1\uffff\1\24\1\35\7\uffff\1\45\4\uffff\1\101\2\uffff\1\47\3\uffff\1\26\1\uffff\1\43\2\uffff\1\42\3\uffff\1\77";
     static final String DFA12_specialS =
-        "\1\1\53\uffff\1\2\1\0\u01d2\uffff}>";
+        "\1\2\53\uffff\1\0\1\1\u01bd\uffff}>";
     static final String[] DFA12_transitionS = {
-            "\11\60\2\57\2\60\1\57\22\60\1\57\1\4\1\54\4\60\1\55\4\60\1\47\1\52\1\60\1\56\12\53\1\46\1\50\1\5\1\3\1\6\2\60\1\52\1\12\1\52\1\43\1\25\1\20\1\7\1\52\1\35\2\52\1\36\1\32\4\52\1\11\1\21\1\40\1\26\3\52\1\10\1\52\1\44\1\60\1\45\1\51\1\52\1\60\1\30\1\14\1\37\1\16\1\17\1\2\1\52\1\22\1\23\1\52\1\15\1\31\1\41\1\52\1\27\1\34\1\52\1\33\1\24\1\1\1\52\1\42\1\13\3\52\uff85\60",
+            "\11\60\2\57\2\60\1\57\22\60\1\57\1\4\1\54\4\60\1\55\4\60\1\47\1\52\1\60\1\56\12\53\1\46\1\50\1\5\1\3\1\6\2\60\1\52\1\13\1\52\1\43\1\24\1\21\1\10\1\52\1\34\2\52\1\35\1\30\1\7\3\52\1\12\1\22\1\40\1\25\3\52\1\11\1\52\1\44\1\60\1\45\1\51\1\52\1\60\1\26\1\15\1\37\1\17\1\20\1\2\1\52\1\31\1\23\1\52\1\16\1\27\1\41\2\52\1\33\1\52\1\32\1\36\1\1\1\52\1\42\1\14\3\52\uff85\60",
             "\1\62\11\uffff\1\63\2\uffff\1\61",
             "\1\65\12\uffff\1\67\2\uffff\1\66",
             "\1\70",
             "\1\72",
             "\1\73",
             "\1\75",
-            "\1\77\16\uffff\1\100",
-            "\1\101",
+            "\1\77",
+            "\1\100\16\uffff\1\101",
             "\1\102",
-            "\1\103\36\uffff\1\105\5\uffff\1\104",
-            "\1\106",
-            "\1\107\10\uffff\1\110",
-            "\1\111",
-            "\1\113\7\uffff\1\112",
-            "\1\117\1\114\1\116\11\uffff\1\115",
-            "\1\120",
-            "\1\122\1\uffff\1\123\16\uffff\1\121",
-            "\1\124",
+            "\1\103",
+            "\1\104\36\uffff\1\106\5\uffff\1\105",
+            "\1\107",
+            "\1\110\10\uffff\1\111",
+            "\1\112",
+            "\1\114\7\uffff\1\113",
+            "\1\120\1\115\1\117\11\uffff\1\116",
+            "\1\121",
+            "\1\123\1\uffff\1\124\16\uffff\1\122",
             "\1\126\7\uffff\1\125",
-            "\1\130\16\uffff\1\127",
-            "\1\131\11\uffff\1\132",
+            "\1\127\11\uffff\1\130",
+            "\1\131",
+            "\1\132",
             "\1\133",
             "\1\134",
             "\1\135",
-            "\1\136",
-            "\1\137",
-            "\1\140\17\uffff\1\141",
-            "\1\143\20\uffff\1\142",
-            "\1\144",
-            "\1\145",
+            "\1\136\17\uffff\1\137",
+            "\1\141\20\uffff\1\140",
+            "\1\142",
+            "\1\143",
+            "\1\145\16\uffff\1\144",
             "\1\147\6\uffff\1\146",
             "\1\150",
             "\1\152\15\uffff\1\151",
@@ -2874,33 +2845,33 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0084",
             "\1\u0085",
             "\1\u0086",
+            "\1\u0087",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u0088",
             "\1\u0089",
             "\1\u008a",
             "\1\u008b",
-            "\1\u008d\3\uffff\1\u008c",
-            "\1\u008e",
+            "\1\u008c",
+            "\1\u008e\3\uffff\1\u008d",
             "\1\u008f",
             "\1\u0090",
-            "\1\u0091\20\uffff\1\u0092",
-            "\1\u0093",
-            "\1\u0095\1\u0094",
-            "\1\u0096\1\u0097",
-            "\1\u0098",
+            "\1\u0091",
+            "\1\u0092\20\uffff\1\u0093",
+            "\1\u0094",
+            "\1\u0096\1\u0095",
+            "\1\u0097",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0099",
             "\1\u009a",
             "\1\u009b",
             "\1\u009c",
             "\1\u009d",
             "\1\u009e",
-            "\1\u009f",
-            "\1\u00a0",
+            "\1\u009f\1\u00a0",
             "\1\u00a1",
             "\1\u00a2",
-            "\1\u00a3",
-            "\1\u00a4",
-            "\1\u00a6\5\uffff\1\u00a5",
+            "\1\u00a4\5\uffff\1\u00a3",
+            "\1\u00a5",
+            "\1\u00a6",
             "\1\u00a7",
             "\1\u00a8",
             "\1\u00a9",
@@ -2931,16 +2902,16 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00b8",
             "\1\u00b9",
             "\1\u00ba",
+            "\1\u00bb",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00bc",
             "\1\u00bd",
             "\1\u00be",
             "\1\u00bf",
             "\1\u00c0",
+            "\1\u00c1",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00c3",
             "\1\u00c4",
             "\1\u00c5",
             "\1\u00c6",
@@ -2953,16 +2924,17 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00cd",
             "\1\u00ce",
             "\1\u00cf",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00d1",
+            "\1\u00d0",
             "",
+            "\1\u00d1",
             "\1\u00d2",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\23\64\1\u00d3\6\64",
+            "\1\u00d3",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u00d5",
             "\1\u00d6",
             "\1\u00d7",
-            "\1\u00d8",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u00d9",
             "\1\u00da",
             "\1\u00db",
             "\1\u00dc",
@@ -2970,8 +2942,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00de",
             "\1\u00df",
             "\1\u00e0",
-            "\1\u00e1",
-            "\1\u00e2",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\23\64\1\u00e1\6\64",
             "\1\u00e3",
             "\1\u00e4",
             "\1\u00e5",
@@ -2986,49 +2957,49 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00ee",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00f0",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u00f1",
             "\1\u00f2",
-            "",
             "\1\u00f3",
+            "",
             "\1\u00f4",
             "\1\u00f5",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\16\64\1\u00f6\13\64",
+            "\1\u00f6",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\16\64\1\u00f7\13\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "",
-            "\1\u00f9",
             "\1\u00fa",
             "\1\u00fb",
             "\1\u00fc",
+            "\1\u00fd",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00fe",
-            "\1\64\2\uffff\12\64\7\uffff\4\64\1\u00ff\25\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u0101",
+            "\1\u00ff",
+            "\1\64\2\uffff\12\64\7\uffff\4\64\1\u0100\25\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0102",
             "\1\u0103",
             "\1\u0104",
             "\1\u0105",
             "\1\u0106",
-            "",
             "\1\u0107",
             "\1\u0108",
             "\1\u0109",
-            "",
             "\1\u010a",
+            "",
             "\1\u010b",
             "\1\u010c",
             "\1\u010d",
             "",
             "\1\u010e",
-            "\1\u010f",
-            "\1\u0110",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0110",
+            "\1\u0111",
             "\1\u0112",
             "\1\u0113",
-            "\1\u0114",
-            "\1\u0115",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0115",
+            "\1\u0116",
+            "",
             "\1\u0117",
             "\1\u0118",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
@@ -3042,6 +3013,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0121",
             "",
+            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0123",
             "\1\u0124",
@@ -3064,37 +3036,38 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0131",
             "\1\u0132",
             "\1\u0133",
-            "\1\u0134",
-            "\1\u0136\34\uffff\1\u0135",
-            "\1\u0137\34\uffff\1\u0138",
-            "\1\u0139",
+            "\1\u0134\34\uffff\1\u0135",
+            "\1\u0136",
+            "\1\u0137",
+            "\1\u0138",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u013a",
             "\1\u013b",
             "\1\u013c",
+            "",
             "\1\u013d",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u013e",
             "\1\u013f",
             "\1\u0140",
             "",
             "\1\u0141",
             "\1\u0142",
             "\1\u0143",
-            "\1\u0144",
-            "",
-            "\1\u0145",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0146",
+            "\1\u0147",
             "\1\u0148",
             "\1\u0149",
-            "\1\u014a",
-            "\1\u014b",
             "",
             "",
-            "\1\u014c",
+            "\1\u014a",
             "",
-            "\1\u014d",
+            "\1\u014b",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u014d",
+            "\1\u014e",
             "\1\u014f",
             "\1\u0150",
             "\1\u0151",
@@ -3104,46 +3077,47 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0155",
             "\1\u0156",
             "\1\u0157",
-            "\1\u0158",
-            "\1\u0159",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0159",
+            "\1\u015a",
             "\1\u015b",
             "\1\u015c",
-            "\1\u015d",
-            "\1\u015e",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u015e",
+            "\1\u015f",
             "\1\u0160",
+            "",
             "\1\u0161",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0162",
+            "\1\u0163",
             "\1\u0164",
             "\1\u0165",
-            "\1\u0166",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0167",
-            "",
-            "\1\u0168",
-            "\1\u0169",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u016a",
-            "\1\u016b",
+            "",
+            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u016c",
             "\1\u016d",
             "\1\u016e",
-            "",
-            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u0170",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
             "\1\u0171",
             "\1\u0172",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "",
             "\1\u0175",
             "\1\u0176",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0177",
+            "\1\u0178",
             "\1\u0179",
             "\1\u017a",
             "\1\u017b",
+            "",
             "\1\u017c",
             "\1\u017d",
             "\1\u017e",
@@ -3153,165 +3127,141 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0181",
             "\1\u0182",
             "\1\u0183",
-            "",
             "\1\u0184",
             "\1\u0185",
-            "",
-            "",
             "\1\u0186",
             "\1\u0187",
-            "\1\u0188",
+            "",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
+            "",
             "\1\u0189",
+            "",
             "\1\u018a",
             "\1\u018b",
             "\1\u018c",
-            "\1\u018d",
-            "",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u018f",
-            "",
-            "\1\u0190",
-            "\1\u0191",
-            "\1\u0192",
             "",
             "",
-            "\1\u0193",
-            "\1\u0194",
+            "\1\u018d",
+            "\1\u018e",
             "",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0192",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0194",
+            "\1\u0195",
+            "\1\u0196",
+            "\1\u0197",
             "\1\u0198",
+            "\1\u0199",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u019c\1\u019b",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u019a",
-            "\1\u019b",
-            "\1\u019c",
-            "\1\u019d",
             "\1\u019e",
             "\1\u019f",
             "\1\u01a0",
             "\1\u01a1",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01a4\1\u01a3",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
+            "\1\u01a3",
+            "\1\u01a4",
+            "\1\u01a5",
             "\1\u01a6",
             "\1\u01a7",
             "\1\u01a8",
+            "",
+            "",
+            "",
             "\1\u01a9",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
+            "\1\u01aa",
             "\1\u01ab",
             "\1\u01ac",
             "\1\u01ad",
             "\1\u01ae",
             "\1\u01af",
-            "\1\u01b0",
-            "",
-            "",
             "",
+            "\1\u01b0",
             "\1\u01b1",
             "",
             "\1\u01b2",
-            "\1\u01b3",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01b4",
-            "\1\u01b5",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
             "\1\u01b6",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01b8",
             "\1\u01b9",
-            "",
             "\1\u01ba",
             "\1\u01bb",
-            "",
-            "\1\u01bc",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01bd",
-            "\1\u01be",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "",
-            "\1\u01c0",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01c0",
+            "\1\u01c1",
             "\1\u01c2",
             "\1\u01c3",
             "\1\u01c4",
-            "\1\u01c5",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01c7",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01ca",
-            "\1\u01cb",
             "",
-            "\1\u01cc",
-            "\1\u01cd",
-            "\1\u01ce",
-            "\1\u01cf",
-            "\1\u01d0",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01d2",
+            "\1\u01c6",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
-            "\1\u01d4",
+            "\1\u01c8",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01d7",
+            "\1\u01cb",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01da",
-            "\1\u01db",
-            "\1\u01dc",
-            "\1\u01dd",
-            "\1\u01de",
-            "\1\u01df",
+            "\1\u01ce",
+            "\1\u01cf",
+            "\1\u01d0",
+            "\1\u01d1",
             "",
-            "\1\u01e0",
+            "\1\u01d2",
             "",
-            "\1\u01e1",
+            "\1\u01d3",
             "",
             "",
-            "\1\u01e2",
+            "\1\u01d4",
             "",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01e4",
-            "\1\u01e5",
-            "\1\u01e6",
-            "\1\u01e7",
-            "\1\u01e8",
-            "\1\u01e9",
+            "\1\u01d6",
+            "\1\u01d7",
+            "\1\u01d8",
+            "\1\u01d9",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01eb",
+            "\1\u01db",
             "",
-            "\1\u01ec",
-            "\1\u01ed",
+            "\1\u01dc",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01ef",
-            "\1\u01f0",
-            "\1\u01f1",
+            "\1\u01de",
+            "\1\u01df",
             "",
-            "\1\u01f2",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01e0",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
-            "\1\u01f5",
-            "\1\u01f6",
+            "\1\u01e2",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01f8",
-            "",
+            "\1\u01e4",
             "",
-            "\1\u01f9",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01e5",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01fc",
-            "",
+            "\1\u01e7",
             "",
-            "\1\u01fd",
-            "\1\u01fe",
+            "\1\u01e8",
+            "\1\u01e9",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             ""
     };
@@ -3346,13 +3296,23 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             this.transition = DFA12_transition;
         }
         public String getDescription() {
-            return "1:1: Tokens : ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | T__86 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER );";
+            return "1:1: Tokens : ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER );";
         }
         public int specialStateTransition(int s, IntStream _input) throws NoViableAltException {
             IntStream input = _input;
         	int _s = s;
             switch ( s ) {
                     case 0 : 
+                        int LA12_44 = input.LA(1);
+
+                        s = -1;
+                        if ( ((LA12_44>='\u0000' && LA12_44<='\uFFFF')) ) {s = 115;}
+
+                        else s = 48;
+
+                        if ( s>=0 ) return s;
+                        break;
+                    case 1 : 
                         int LA12_45 = input.LA(1);
 
                         s = -1;
@@ -3362,7 +3322,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         if ( s>=0 ) return s;
                         break;
-                    case 1 : 
+                    case 2 : 
                         int LA12_0 = input.LA(1);
 
                         s = -1;
@@ -3378,53 +3338,53 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else if ( (LA12_0=='>') ) {s = 6;}
 
-                        else if ( (LA12_0=='G') ) {s = 7;}
+                        else if ( (LA12_0=='N') ) {s = 7;}
 
-                        else if ( (LA12_0=='Y') ) {s = 8;}
+                        else if ( (LA12_0=='G') ) {s = 8;}
 
-                        else if ( (LA12_0=='R') ) {s = 9;}
+                        else if ( (LA12_0=='Y') ) {s = 9;}
 
-                        else if ( (LA12_0=='B') ) {s = 10;}
+                        else if ( (LA12_0=='R') ) {s = 10;}
 
-                        else if ( (LA12_0=='w') ) {s = 11;}
+                        else if ( (LA12_0=='B') ) {s = 11;}
 
-                        else if ( (LA12_0=='b') ) {s = 12;}
+                        else if ( (LA12_0=='w') ) {s = 12;}
 
-                        else if ( (LA12_0=='k') ) {s = 13;}
+                        else if ( (LA12_0=='b') ) {s = 13;}
 
-                        else if ( (LA12_0=='d') ) {s = 14;}
+                        else if ( (LA12_0=='k') ) {s = 14;}
 
-                        else if ( (LA12_0=='e') ) {s = 15;}
+                        else if ( (LA12_0=='d') ) {s = 15;}
 
-                        else if ( (LA12_0=='F') ) {s = 16;}
+                        else if ( (LA12_0=='e') ) {s = 16;}
 
-                        else if ( (LA12_0=='S') ) {s = 17;}
+                        else if ( (LA12_0=='F') ) {s = 17;}
 
-                        else if ( (LA12_0=='h') ) {s = 18;}
+                        else if ( (LA12_0=='S') ) {s = 18;}
 
                         else if ( (LA12_0=='i') ) {s = 19;}
 
-                        else if ( (LA12_0=='s') ) {s = 20;}
+                        else if ( (LA12_0=='E') ) {s = 20;}
 
-                        else if ( (LA12_0=='E') ) {s = 21;}
+                        else if ( (LA12_0=='U') ) {s = 21;}
 
-                        else if ( (LA12_0=='U') ) {s = 22;}
+                        else if ( (LA12_0=='a') ) {s = 22;}
 
-                        else if ( (LA12_0=='o') ) {s = 23;}
+                        else if ( (LA12_0=='l') ) {s = 23;}
 
-                        else if ( (LA12_0=='a') ) {s = 24;}
+                        else if ( (LA12_0=='M') ) {s = 24;}
 
-                        else if ( (LA12_0=='l') ) {s = 25;}
+                        else if ( (LA12_0=='h') ) {s = 25;}
 
-                        else if ( (LA12_0=='M') ) {s = 26;}
+                        else if ( (LA12_0=='r') ) {s = 26;}
 
-                        else if ( (LA12_0=='r') ) {s = 27;}
+                        else if ( (LA12_0=='p') ) {s = 27;}
 
-                        else if ( (LA12_0=='p') ) {s = 28;}
+                        else if ( (LA12_0=='I') ) {s = 28;}
 
-                        else if ( (LA12_0=='I') ) {s = 29;}
+                        else if ( (LA12_0=='L') ) {s = 29;}
 
-                        else if ( (LA12_0=='L') ) {s = 30;}
+                        else if ( (LA12_0=='s') ) {s = 30;}
 
                         else if ( (LA12_0=='c') ) {s = 31;}
 
@@ -3448,7 +3408,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else if ( (LA12_0=='^') ) {s = 41;}
 
-                        else if ( (LA12_0=='-'||LA12_0=='A'||LA12_0=='C'||LA12_0=='H'||(LA12_0>='J' && LA12_0<='K')||(LA12_0>='N' && LA12_0<='Q')||(LA12_0>='V' && LA12_0<='X')||LA12_0=='Z'||LA12_0=='_'||LA12_0=='g'||LA12_0=='j'||LA12_0=='n'||LA12_0=='q'||LA12_0=='u'||(LA12_0>='x' && LA12_0<='z')) ) {s = 42;}
+                        else if ( (LA12_0=='-'||LA12_0=='A'||LA12_0=='C'||LA12_0=='H'||(LA12_0>='J' && LA12_0<='K')||(LA12_0>='O' && LA12_0<='Q')||(LA12_0>='V' && LA12_0<='X')||LA12_0=='Z'||LA12_0=='_'||LA12_0=='g'||LA12_0=='j'||(LA12_0>='n' && LA12_0<='o')||LA12_0=='q'||LA12_0=='u'||(LA12_0>='x' && LA12_0<='z')) ) {s = 42;}
 
                         else if ( ((LA12_0>='0' && LA12_0<='9')) ) {s = 43;}
 
@@ -3462,16 +3422,6 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else if ( ((LA12_0>='\u0000' && LA12_0<='\b')||(LA12_0>='\u000B' && LA12_0<='\f')||(LA12_0>='\u000E' && LA12_0<='\u001F')||(LA12_0>='#' && LA12_0<='&')||(LA12_0>='(' && LA12_0<='+')||LA12_0=='.'||(LA12_0>='?' && LA12_0<='@')||LA12_0=='\\'||LA12_0=='`'||(LA12_0>='{' && LA12_0<='\uFFFF')) ) {s = 48;}
 
-                        if ( s>=0 ) return s;
-                        break;
-                    case 2 : 
-                        int LA12_44 = input.LA(1);
-
-                        s = -1;
-                        if ( ((LA12_44>='\u0000' && LA12_44<='\uFFFF')) ) {s = 115;}
-
-                        else s = 48;
-
                         if ( s>=0 ) return s;
                         break;
             }
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLParser.java b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLParser.java
index c49cc9959aed1344f4e376323b5551f7d0b1ed7d..a17ad8f0b8f658df3bd0f04c04970b5b0cd09606 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLParser.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl.ide/src-gen/de/fhmuenster/masterthesis/ide/contentassist/antlr/internal/InternalTestgeneratorDSLParser.java
@@ -22,7 +22,7 @@ import java.util.ArrayList;
 @SuppressWarnings("all")
 public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssistParser {
     public static final String[] tokenNames = new String[] {
-        "<invalid>", "<EOR>", "<DOWN>", "<UP>", "RULE_DECLARATION_FINISHED", "RULE_ASSOCIATION", "RULE_LIST_OPEN", "RULE_LIST_CLOSED", "RULE_SEPARATOR", "RULE_ID", "RULE_STRING", "RULE_INT", "RULE_ML_COMMENT", "RULE_SL_COMMENT", "RULE_WS", "RULE_ANY_OTHER", "'true'", "'false'", "'=='", "'!='", "'<'", "'>'", "'<='", "'>='", "'GREEN'", "'YELLOW'", "'RED'", "'BPMNDiagram'", "'with'", "'testpackage'", "'bpmn'", "'key'", "'dmn'", "'embedded'", "'FlowElement'", "'StartEvent'", "'hardcoded'", "'inputs'", "'startVariables'", "'EndEvent'", "'UserTask'", "'inputVariables'", "'outputVariables'", "'and'", "'label'", "'ManualTask'", "'ScriptTask'", "'ServiceTask'", "'delegate'", "'external'", "'BusinessRuleTask'", "'resultVariable'", "'Gateway'", "'SequenceFlow'", "'expression'", "'ExternalTopic'", "'String'", "'proposals'", "'Integer'", "'Boolean'", "'Loop'", "'starts'", "'follows'", "'by'", "'ends'", "'has'", "'complexity'", "'passed'", "'Flow'", "'for'", "'elements'", "'flag'", "'without'", "'Test'", "'priority'", "'mocks'", "'variables'", "'check'", "'='", "'ExternalServiceMock'", "'topic'", "'DelegateMock'", "'rule'", "'if'", "'set'", "'manual'", "'setter'"
+        "<invalid>", "<EOR>", "<DOWN>", "<UP>", "RULE_DECLARATION_FINISHED", "RULE_ASSOCIATION", "RULE_LIST_OPEN", "RULE_LIST_CLOSED", "RULE_SEPARATOR", "RULE_ID", "RULE_STRING", "RULE_INT", "RULE_ML_COMMENT", "RULE_SL_COMMENT", "RULE_WS", "RULE_ANY_OTHER", "'true'", "'false'", "'=='", "'!='", "'<'", "'>'", "'<='", "'>='", "'NONE'", "'GREEN'", "'YELLOW'", "'RED'", "'BPMNDiagram'", "'with'", "'testpackage'", "'bpmn'", "'key'", "'dmn'", "'embedded'", "'FlowElement'", "'StartEvent'", "'inputVariables'", "'EndEvent'", "'UserTask'", "'and'", "'label'", "'ManualTask'", "'ScriptTask'", "'ServiceTask'", "'delegate'", "'external'", "'hardcoded'", "'inputs'", "'BusinessRuleTask'", "'resultVariable'", "'Gateway'", "'SequenceFlow'", "'expression'", "'ExternalTopic'", "'String'", "'proposals'", "'Integer'", "'Boolean'", "'Loop'", "'starts'", "'follows'", "'by'", "'ends'", "'has'", "'complexity'", "'passed'", "'Flow'", "'for'", "'elements'", "'flag'", "'without'", "'Test'", "'priority'", "'mocks'", "'variables'", "'check'", "'='", "'ExternalServiceMock'", "'topic'", "'DelegateMock'", "'rule'", "'if'", "'set'", "'manual'", "'setter'"
     };
     public static final int T__50=50;
     public static final int T__19=19;
@@ -106,7 +106,6 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
     public static final int T__41=41;
     public static final int T__85=85;
     public static final int T__42=42;
-    public static final int T__86=86;
     public static final int T__43=43;
 
     // delegates
@@ -194,7 +193,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                 int alt1=2;
                 int LA1_0 = input.LA(1);
 
-                if ( (LA1_0==27||LA1_0==34||(LA1_0>=55 && LA1_0<=56)||(LA1_0>=58 && LA1_0<=60)||LA1_0==68||LA1_0==73||LA1_0==79||LA1_0==81) ) {
+                if ( (LA1_0==28||LA1_0==35||(LA1_0>=54 && LA1_0<=55)||(LA1_0>=57 && LA1_0<=59)||LA1_0==67||LA1_0==72||LA1_0==78||LA1_0==80) ) {
                     alt1=1;
                 }
 
@@ -1425,31 +1424,31 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "ruleFlowElementReference"
-    // InternalTestgeneratorDSL.g:462:1: ruleFlowElementReference : ( ( rule__FlowElementReference__RefAssignment ) ) ;
+    // InternalTestgeneratorDSL.g:462:1: ruleFlowElementReference : ( ( rule__FlowElementReference__Group__0 ) ) ;
     public final void ruleFlowElementReference() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:466:2: ( ( ( rule__FlowElementReference__RefAssignment ) ) )
-            // InternalTestgeneratorDSL.g:467:2: ( ( rule__FlowElementReference__RefAssignment ) )
+            // InternalTestgeneratorDSL.g:466:2: ( ( ( rule__FlowElementReference__Group__0 ) ) )
+            // InternalTestgeneratorDSL.g:467:2: ( ( rule__FlowElementReference__Group__0 ) )
             {
-            // InternalTestgeneratorDSL.g:467:2: ( ( rule__FlowElementReference__RefAssignment ) )
-            // InternalTestgeneratorDSL.g:468:3: ( rule__FlowElementReference__RefAssignment )
+            // InternalTestgeneratorDSL.g:467:2: ( ( rule__FlowElementReference__Group__0 ) )
+            // InternalTestgeneratorDSL.g:468:3: ( rule__FlowElementReference__Group__0 )
             {
-             before(grammarAccess.getFlowElementReferenceAccess().getRefAssignment()); 
-            // InternalTestgeneratorDSL.g:469:3: ( rule__FlowElementReference__RefAssignment )
-            // InternalTestgeneratorDSL.g:469:4: rule__FlowElementReference__RefAssignment
+             before(grammarAccess.getFlowElementReferenceAccess().getGroup()); 
+            // InternalTestgeneratorDSL.g:469:3: ( rule__FlowElementReference__Group__0 )
+            // InternalTestgeneratorDSL.g:469:4: rule__FlowElementReference__Group__0
             {
             pushFollow(FOLLOW_2);
-            rule__FlowElementReference__RefAssignment();
+            rule__FlowElementReference__Group__0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getFlowElementReferenceAccess().getRefAssignment()); 
+             after(grammarAccess.getFlowElementReferenceAccess().getGroup()); 
 
             }
 
@@ -4565,45 +4564,45 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             // InternalTestgeneratorDSL.g:1486:1: ( ( ruleBPMNDiagram ) | ( ruleFlowElement ) | ( ruleVariable ) | ( ruleFlow ) | ( ruleTest ) | ( ruleMock ) | ( ruleExternalTopic ) | ( ruleLoop ) )
             int alt2=8;
             switch ( input.LA(1) ) {
-            case 27:
+            case 28:
                 {
                 alt2=1;
                 }
                 break;
-            case 34:
+            case 35:
                 {
                 alt2=2;
                 }
                 break;
-            case 56:
+            case 55:
+            case 57:
             case 58:
-            case 59:
                 {
                 alt2=3;
                 }
                 break;
-            case 68:
+            case 67:
                 {
                 alt2=4;
                 }
                 break;
-            case 73:
+            case 72:
                 {
                 alt2=5;
                 }
                 break;
-            case 79:
-            case 81:
+            case 78:
+            case 80:
                 {
                 alt2=6;
                 }
                 break;
-            case 55:
+            case 54:
                 {
                 alt2=7;
                 }
                 break;
-            case 60:
+            case 59:
                 {
                 alt2=8;
                 }
@@ -4995,7 +4994,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             int alt4=2;
             int LA4_0 = input.LA(1);
 
-            if ( (LA4_0==34) ) {
+            if ( (LA4_0==35) ) {
                 int LA4_1 = input.LA(2);
 
                 if ( (LA4_1==RULE_ID) ) {
@@ -5004,16 +5003,16 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                     if ( (LA4_2==RULE_ASSOCIATION) ) {
                         int LA4_3 = input.LA(4);
 
-                        if ( (LA4_3==47) ) {
+                        if ( (LA4_3==44) ) {
                             int LA4_4 = input.LA(5);
 
-                            if ( (LA4_4==28) ) {
+                            if ( (LA4_4==29) ) {
                                 int LA4_5 = input.LA(6);
 
-                                if ( (LA4_5==49) ) {
+                                if ( (LA4_5==46) ) {
                                     alt4=2;
                                 }
-                                else if ( (LA4_5==48) ) {
+                                else if ( (LA4_5==45) ) {
                                     alt4=1;
                                 }
                                 else {
@@ -5123,17 +5122,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             // InternalTestgeneratorDSL.g:1627:1: ( ( ruleStringVariable ) | ( ruleIntVariable ) | ( ruleBooleanVariable ) )
             int alt5=3;
             switch ( input.LA(1) ) {
-            case 56:
+            case 55:
                 {
                 alt5=1;
                 }
                 break;
-            case 58:
+            case 57:
                 {
                 alt5=2;
                 }
                 break;
-            case 59:
+            case 58:
                 {
                 alt5=3;
                 }
@@ -5234,8 +5233,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             if ( (LA6_0==RULE_ID) ) {
                 int LA6_1 = input.LA(2);
 
-                if ( (LA6_1==78) ) {
+                if ( (LA6_1==77) ) {
                     switch ( input.LA(3) ) {
+                    case 16:
+                    case 17:
+                        {
+                        alt6=3;
+                        }
+                        break;
                     case RULE_INT:
                         {
                         alt6=2;
@@ -5246,12 +5251,6 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                         alt6=1;
                         }
                         break;
-                    case 16:
-                    case 17:
-                        {
-                        alt6=3;
-                        }
-                        break;
                     default:
                         NoViableAltException nvae =
                             new NoViableAltException("", 6, 2, input);
@@ -5704,10 +5703,10 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             int alt10=2;
             int LA10_0 = input.LA(1);
 
-            if ( (LA10_0==79) ) {
+            if ( (LA10_0==78) ) {
                 alt10=1;
             }
-            else if ( (LA10_0==81) ) {
+            else if ( (LA10_0==80) ) {
                 alt10=2;
             }
             else {
@@ -5788,15 +5787,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                 case 18:
                     {
                     switch ( input.LA(3) ) {
-                    case 16:
-                    case 17:
+                    case RULE_INT:
                         {
-                        alt11=3;
+                        alt11=2;
                         }
                         break;
-                    case RULE_INT:
+                    case 16:
+                    case 17:
                         {
-                        alt11=2;
+                        alt11=3;
                         }
                         break;
                     case RULE_STRING:
@@ -5816,9 +5815,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                 case 19:
                     {
                     switch ( input.LA(3) ) {
-                    case RULE_STRING:
+                    case RULE_INT:
                         {
-                        alt11=1;
+                        alt11=2;
                         }
                         break;
                     case 16:
@@ -5827,9 +5826,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                         alt11=3;
                         }
                         break;
-                    case RULE_INT:
+                    case RULE_STRING:
                         {
-                        alt11=2;
+                        alt11=1;
                         }
                         break;
                     default:
@@ -6379,14 +6378,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flag__Alternatives"
-    // InternalTestgeneratorDSL.g:1908:1: rule__Flag__Alternatives : ( ( ( 'GREEN' ) ) | ( ( 'YELLOW' ) ) | ( ( 'RED' ) ) );
+    // InternalTestgeneratorDSL.g:1908:1: rule__Flag__Alternatives : ( ( ( 'NONE' ) ) | ( ( 'GREEN' ) ) | ( ( 'YELLOW' ) ) | ( ( 'RED' ) ) );
     public final void rule__Flag__Alternatives() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1912:1: ( ( ( 'GREEN' ) ) | ( ( 'YELLOW' ) ) | ( ( 'RED' ) ) )
-            int alt16=3;
+            // InternalTestgeneratorDSL.g:1912:1: ( ( ( 'NONE' ) ) | ( ( 'GREEN' ) ) | ( ( 'YELLOW' ) ) | ( ( 'RED' ) ) )
+            int alt16=4;
             switch ( input.LA(1) ) {
             case 24:
                 {
@@ -6403,6 +6402,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                 alt16=3;
                 }
                 break;
+            case 27:
+                {
+                alt16=4;
+                }
+                break;
             default:
                 NoViableAltException nvae =
                     new NoViableAltException("", 16, 0, input);
@@ -6412,20 +6416,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             switch (alt16) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:1913:2: ( ( 'GREEN' ) )
+                    // InternalTestgeneratorDSL.g:1913:2: ( ( 'NONE' ) )
                     {
-                    // InternalTestgeneratorDSL.g:1913:2: ( ( 'GREEN' ) )
-                    // InternalTestgeneratorDSL.g:1914:3: ( 'GREEN' )
+                    // InternalTestgeneratorDSL.g:1913:2: ( ( 'NONE' ) )
+                    // InternalTestgeneratorDSL.g:1914:3: ( 'NONE' )
                     {
-                     before(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0()); 
-                    // InternalTestgeneratorDSL.g:1915:3: ( 'GREEN' )
-                    // InternalTestgeneratorDSL.g:1915:4: 'GREEN'
+                     before(grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0()); 
+                    // InternalTestgeneratorDSL.g:1915:3: ( 'NONE' )
+                    // InternalTestgeneratorDSL.g:1915:4: 'NONE'
                     {
                     match(input,24,FOLLOW_2); 
 
                     }
 
-                     after(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0()); 
+                     after(grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0()); 
 
                     }
 
@@ -6433,20 +6437,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:1919:2: ( ( 'YELLOW' ) )
+                    // InternalTestgeneratorDSL.g:1919:2: ( ( 'GREEN' ) )
                     {
-                    // InternalTestgeneratorDSL.g:1919:2: ( ( 'YELLOW' ) )
-                    // InternalTestgeneratorDSL.g:1920:3: ( 'YELLOW' )
+                    // InternalTestgeneratorDSL.g:1919:2: ( ( 'GREEN' ) )
+                    // InternalTestgeneratorDSL.g:1920:3: ( 'GREEN' )
                     {
-                     before(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1()); 
-                    // InternalTestgeneratorDSL.g:1921:3: ( 'YELLOW' )
-                    // InternalTestgeneratorDSL.g:1921:4: 'YELLOW'
+                     before(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1()); 
+                    // InternalTestgeneratorDSL.g:1921:3: ( 'GREEN' )
+                    // InternalTestgeneratorDSL.g:1921:4: 'GREEN'
                     {
                     match(input,25,FOLLOW_2); 
 
                     }
 
-                     after(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1()); 
+                     after(grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1()); 
 
                     }
 
@@ -6454,20 +6458,41 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:1925:2: ( ( 'RED' ) )
+                    // InternalTestgeneratorDSL.g:1925:2: ( ( 'YELLOW' ) )
                     {
-                    // InternalTestgeneratorDSL.g:1925:2: ( ( 'RED' ) )
-                    // InternalTestgeneratorDSL.g:1926:3: ( 'RED' )
+                    // InternalTestgeneratorDSL.g:1925:2: ( ( 'YELLOW' ) )
+                    // InternalTestgeneratorDSL.g:1926:3: ( 'YELLOW' )
                     {
-                     before(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2()); 
-                    // InternalTestgeneratorDSL.g:1927:3: ( 'RED' )
-                    // InternalTestgeneratorDSL.g:1927:4: 'RED'
+                     before(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2()); 
+                    // InternalTestgeneratorDSL.g:1927:3: ( 'YELLOW' )
+                    // InternalTestgeneratorDSL.g:1927:4: 'YELLOW'
                     {
                     match(input,26,FOLLOW_2); 
 
                     }
 
-                     after(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2()); 
+                     after(grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2()); 
+
+                    }
+
+
+                    }
+                    break;
+                case 4 :
+                    // InternalTestgeneratorDSL.g:1931:2: ( ( 'RED' ) )
+                    {
+                    // InternalTestgeneratorDSL.g:1931:2: ( ( 'RED' ) )
+                    // InternalTestgeneratorDSL.g:1932:3: ( 'RED' )
+                    {
+                     before(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3()); 
+                    // InternalTestgeneratorDSL.g:1933:3: ( 'RED' )
+                    // InternalTestgeneratorDSL.g:1933:4: 'RED'
+                    {
+                    match(input,27,FOLLOW_2); 
+
+                    }
+
+                     after(grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3()); 
 
                     }
 
@@ -6492,14 +6517,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__0"
-    // InternalTestgeneratorDSL.g:1935:1: rule__BPMNDiagram__Group__0 : rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1 ;
+    // InternalTestgeneratorDSL.g:1941:1: rule__BPMNDiagram__Group__0 : rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1 ;
     public final void rule__BPMNDiagram__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1939:1: ( rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1 )
-            // InternalTestgeneratorDSL.g:1940:2: rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1
+            // InternalTestgeneratorDSL.g:1945:1: ( rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1 )
+            // InternalTestgeneratorDSL.g:1946:2: rule__BPMNDiagram__Group__0__Impl rule__BPMNDiagram__Group__1
             {
             pushFollow(FOLLOW_4);
             rule__BPMNDiagram__Group__0__Impl();
@@ -6530,20 +6555,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:1947:1: rule__BPMNDiagram__Group__0__Impl : ( 'BPMNDiagram' ) ;
+    // InternalTestgeneratorDSL.g:1953:1: rule__BPMNDiagram__Group__0__Impl : ( 'BPMNDiagram' ) ;
     public final void rule__BPMNDiagram__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1951:1: ( ( 'BPMNDiagram' ) )
-            // InternalTestgeneratorDSL.g:1952:1: ( 'BPMNDiagram' )
+            // InternalTestgeneratorDSL.g:1957:1: ( ( 'BPMNDiagram' ) )
+            // InternalTestgeneratorDSL.g:1958:1: ( 'BPMNDiagram' )
             {
-            // InternalTestgeneratorDSL.g:1952:1: ( 'BPMNDiagram' )
-            // InternalTestgeneratorDSL.g:1953:2: 'BPMNDiagram'
+            // InternalTestgeneratorDSL.g:1958:1: ( 'BPMNDiagram' )
+            // InternalTestgeneratorDSL.g:1959:2: 'BPMNDiagram'
             {
              before(grammarAccess.getBPMNDiagramAccess().getBPMNDiagramKeyword_0()); 
-            match(input,27,FOLLOW_2); 
+            match(input,28,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getBPMNDiagramKeyword_0()); 
 
             }
@@ -6567,14 +6592,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__1"
-    // InternalTestgeneratorDSL.g:1962:1: rule__BPMNDiagram__Group__1 : rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2 ;
+    // InternalTestgeneratorDSL.g:1968:1: rule__BPMNDiagram__Group__1 : rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2 ;
     public final void rule__BPMNDiagram__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1966:1: ( rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2 )
-            // InternalTestgeneratorDSL.g:1967:2: rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2
+            // InternalTestgeneratorDSL.g:1972:1: ( rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2 )
+            // InternalTestgeneratorDSL.g:1973:2: rule__BPMNDiagram__Group__1__Impl rule__BPMNDiagram__Group__2
             {
             pushFollow(FOLLOW_5);
             rule__BPMNDiagram__Group__1__Impl();
@@ -6605,21 +6630,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:1974:1: rule__BPMNDiagram__Group__1__Impl : ( ( rule__BPMNDiagram__NameAssignment_1 ) ) ;
+    // InternalTestgeneratorDSL.g:1980:1: rule__BPMNDiagram__Group__1__Impl : ( ( rule__BPMNDiagram__NameAssignment_1 ) ) ;
     public final void rule__BPMNDiagram__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1978:1: ( ( ( rule__BPMNDiagram__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:1979:1: ( ( rule__BPMNDiagram__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:1984:1: ( ( ( rule__BPMNDiagram__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:1985:1: ( ( rule__BPMNDiagram__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:1979:1: ( ( rule__BPMNDiagram__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:1980:2: ( rule__BPMNDiagram__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:1985:1: ( ( rule__BPMNDiagram__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:1986:2: ( rule__BPMNDiagram__NameAssignment_1 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:1981:2: ( rule__BPMNDiagram__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:1981:3: rule__BPMNDiagram__NameAssignment_1
+            // InternalTestgeneratorDSL.g:1987:2: ( rule__BPMNDiagram__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:1987:3: rule__BPMNDiagram__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__NameAssignment_1();
@@ -6652,14 +6677,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__2"
-    // InternalTestgeneratorDSL.g:1989:1: rule__BPMNDiagram__Group__2 : rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3 ;
+    // InternalTestgeneratorDSL.g:1995:1: rule__BPMNDiagram__Group__2 : rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3 ;
     public final void rule__BPMNDiagram__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:1993:1: ( rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3 )
-            // InternalTestgeneratorDSL.g:1994:2: rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3
+            // InternalTestgeneratorDSL.g:1999:1: ( rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3 )
+            // InternalTestgeneratorDSL.g:2000:2: rule__BPMNDiagram__Group__2__Impl rule__BPMNDiagram__Group__3
             {
             pushFollow(FOLLOW_6);
             rule__BPMNDiagram__Group__2__Impl();
@@ -6690,20 +6715,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:2001:1: rule__BPMNDiagram__Group__2__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:2007:1: rule__BPMNDiagram__Group__2__Impl : ( 'with' ) ;
     public final void rule__BPMNDiagram__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2005:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:2006:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2011:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:2012:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:2006:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:2007:2: 'with'
+            // InternalTestgeneratorDSL.g:2012:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2013:2: 'with'
             {
              before(grammarAccess.getBPMNDiagramAccess().getWithKeyword_2()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getWithKeyword_2()); 
 
             }
@@ -6727,14 +6752,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__3"
-    // InternalTestgeneratorDSL.g:2016:1: rule__BPMNDiagram__Group__3 : rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4 ;
+    // InternalTestgeneratorDSL.g:2022:1: rule__BPMNDiagram__Group__3 : rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4 ;
     public final void rule__BPMNDiagram__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2020:1: ( rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4 )
-            // InternalTestgeneratorDSL.g:2021:2: rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4
+            // InternalTestgeneratorDSL.g:2026:1: ( rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4 )
+            // InternalTestgeneratorDSL.g:2027:2: rule__BPMNDiagram__Group__3__Impl rule__BPMNDiagram__Group__4
             {
             pushFollow(FOLLOW_7);
             rule__BPMNDiagram__Group__3__Impl();
@@ -6765,20 +6790,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:2028:1: rule__BPMNDiagram__Group__3__Impl : ( 'testpackage' ) ;
+    // InternalTestgeneratorDSL.g:2034:1: rule__BPMNDiagram__Group__3__Impl : ( 'testpackage' ) ;
     public final void rule__BPMNDiagram__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2032:1: ( ( 'testpackage' ) )
-            // InternalTestgeneratorDSL.g:2033:1: ( 'testpackage' )
+            // InternalTestgeneratorDSL.g:2038:1: ( ( 'testpackage' ) )
+            // InternalTestgeneratorDSL.g:2039:1: ( 'testpackage' )
             {
-            // InternalTestgeneratorDSL.g:2033:1: ( 'testpackage' )
-            // InternalTestgeneratorDSL.g:2034:2: 'testpackage'
+            // InternalTestgeneratorDSL.g:2039:1: ( 'testpackage' )
+            // InternalTestgeneratorDSL.g:2040:2: 'testpackage'
             {
              before(grammarAccess.getBPMNDiagramAccess().getTestpackageKeyword_3()); 
-            match(input,29,FOLLOW_2); 
+            match(input,30,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getTestpackageKeyword_3()); 
 
             }
@@ -6802,14 +6827,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__4"
-    // InternalTestgeneratorDSL.g:2043:1: rule__BPMNDiagram__Group__4 : rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5 ;
+    // InternalTestgeneratorDSL.g:2049:1: rule__BPMNDiagram__Group__4 : rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5 ;
     public final void rule__BPMNDiagram__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2047:1: ( rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5 )
-            // InternalTestgeneratorDSL.g:2048:2: rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5
+            // InternalTestgeneratorDSL.g:2053:1: ( rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5 )
+            // InternalTestgeneratorDSL.g:2054:2: rule__BPMNDiagram__Group__4__Impl rule__BPMNDiagram__Group__5
             {
             pushFollow(FOLLOW_5);
             rule__BPMNDiagram__Group__4__Impl();
@@ -6840,21 +6865,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:2055:1: rule__BPMNDiagram__Group__4__Impl : ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) ) ;
+    // InternalTestgeneratorDSL.g:2061:1: rule__BPMNDiagram__Group__4__Impl : ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) ) ;
     public final void rule__BPMNDiagram__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2059:1: ( ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) ) )
-            // InternalTestgeneratorDSL.g:2060:1: ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) )
+            // InternalTestgeneratorDSL.g:2065:1: ( ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) ) )
+            // InternalTestgeneratorDSL.g:2066:1: ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) )
             {
-            // InternalTestgeneratorDSL.g:2060:1: ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) )
-            // InternalTestgeneratorDSL.g:2061:2: ( rule__BPMNDiagram__TestpackageAssignment_4 )
+            // InternalTestgeneratorDSL.g:2066:1: ( ( rule__BPMNDiagram__TestpackageAssignment_4 ) )
+            // InternalTestgeneratorDSL.g:2067:2: ( rule__BPMNDiagram__TestpackageAssignment_4 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getTestpackageAssignment_4()); 
-            // InternalTestgeneratorDSL.g:2062:2: ( rule__BPMNDiagram__TestpackageAssignment_4 )
-            // InternalTestgeneratorDSL.g:2062:3: rule__BPMNDiagram__TestpackageAssignment_4
+            // InternalTestgeneratorDSL.g:2068:2: ( rule__BPMNDiagram__TestpackageAssignment_4 )
+            // InternalTestgeneratorDSL.g:2068:3: rule__BPMNDiagram__TestpackageAssignment_4
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__TestpackageAssignment_4();
@@ -6887,14 +6912,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__5"
-    // InternalTestgeneratorDSL.g:2070:1: rule__BPMNDiagram__Group__5 : rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6 ;
+    // InternalTestgeneratorDSL.g:2076:1: rule__BPMNDiagram__Group__5 : rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6 ;
     public final void rule__BPMNDiagram__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2074:1: ( rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6 )
-            // InternalTestgeneratorDSL.g:2075:2: rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6
+            // InternalTestgeneratorDSL.g:2080:1: ( rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6 )
+            // InternalTestgeneratorDSL.g:2081:2: rule__BPMNDiagram__Group__5__Impl rule__BPMNDiagram__Group__6
             {
             pushFollow(FOLLOW_8);
             rule__BPMNDiagram__Group__5__Impl();
@@ -6925,20 +6950,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:2082:1: rule__BPMNDiagram__Group__5__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:2088:1: rule__BPMNDiagram__Group__5__Impl : ( 'with' ) ;
     public final void rule__BPMNDiagram__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2086:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:2087:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2092:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:2093:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:2087:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:2088:2: 'with'
+            // InternalTestgeneratorDSL.g:2093:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2094:2: 'with'
             {
              before(grammarAccess.getBPMNDiagramAccess().getWithKeyword_5()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getWithKeyword_5()); 
 
             }
@@ -6962,14 +6987,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__6"
-    // InternalTestgeneratorDSL.g:2097:1: rule__BPMNDiagram__Group__6 : rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7 ;
+    // InternalTestgeneratorDSL.g:2103:1: rule__BPMNDiagram__Group__6 : rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7 ;
     public final void rule__BPMNDiagram__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2101:1: ( rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7 )
-            // InternalTestgeneratorDSL.g:2102:2: rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7
+            // InternalTestgeneratorDSL.g:2107:1: ( rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7 )
+            // InternalTestgeneratorDSL.g:2108:2: rule__BPMNDiagram__Group__6__Impl rule__BPMNDiagram__Group__7
             {
             pushFollow(FOLLOW_7);
             rule__BPMNDiagram__Group__6__Impl();
@@ -7000,20 +7025,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:2109:1: rule__BPMNDiagram__Group__6__Impl : ( 'bpmn' ) ;
+    // InternalTestgeneratorDSL.g:2115:1: rule__BPMNDiagram__Group__6__Impl : ( 'bpmn' ) ;
     public final void rule__BPMNDiagram__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2113:1: ( ( 'bpmn' ) )
-            // InternalTestgeneratorDSL.g:2114:1: ( 'bpmn' )
+            // InternalTestgeneratorDSL.g:2119:1: ( ( 'bpmn' ) )
+            // InternalTestgeneratorDSL.g:2120:1: ( 'bpmn' )
             {
-            // InternalTestgeneratorDSL.g:2114:1: ( 'bpmn' )
-            // InternalTestgeneratorDSL.g:2115:2: 'bpmn'
+            // InternalTestgeneratorDSL.g:2120:1: ( 'bpmn' )
+            // InternalTestgeneratorDSL.g:2121:2: 'bpmn'
             {
              before(grammarAccess.getBPMNDiagramAccess().getBpmnKeyword_6()); 
-            match(input,30,FOLLOW_2); 
+            match(input,31,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getBpmnKeyword_6()); 
 
             }
@@ -7037,14 +7062,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__7"
-    // InternalTestgeneratorDSL.g:2124:1: rule__BPMNDiagram__Group__7 : rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8 ;
+    // InternalTestgeneratorDSL.g:2130:1: rule__BPMNDiagram__Group__7 : rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8 ;
     public final void rule__BPMNDiagram__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2128:1: ( rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8 )
-            // InternalTestgeneratorDSL.g:2129:2: rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8
+            // InternalTestgeneratorDSL.g:2134:1: ( rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8 )
+            // InternalTestgeneratorDSL.g:2135:2: rule__BPMNDiagram__Group__7__Impl rule__BPMNDiagram__Group__8
             {
             pushFollow(FOLLOW_5);
             rule__BPMNDiagram__Group__7__Impl();
@@ -7075,21 +7100,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:2136:1: rule__BPMNDiagram__Group__7__Impl : ( ( rule__BPMNDiagram__BpmnAssignment_7 ) ) ;
+    // InternalTestgeneratorDSL.g:2142:1: rule__BPMNDiagram__Group__7__Impl : ( ( rule__BPMNDiagram__BpmnAssignment_7 ) ) ;
     public final void rule__BPMNDiagram__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2140:1: ( ( ( rule__BPMNDiagram__BpmnAssignment_7 ) ) )
-            // InternalTestgeneratorDSL.g:2141:1: ( ( rule__BPMNDiagram__BpmnAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:2146:1: ( ( ( rule__BPMNDiagram__BpmnAssignment_7 ) ) )
+            // InternalTestgeneratorDSL.g:2147:1: ( ( rule__BPMNDiagram__BpmnAssignment_7 ) )
             {
-            // InternalTestgeneratorDSL.g:2141:1: ( ( rule__BPMNDiagram__BpmnAssignment_7 ) )
-            // InternalTestgeneratorDSL.g:2142:2: ( rule__BPMNDiagram__BpmnAssignment_7 )
+            // InternalTestgeneratorDSL.g:2147:1: ( ( rule__BPMNDiagram__BpmnAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:2148:2: ( rule__BPMNDiagram__BpmnAssignment_7 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getBpmnAssignment_7()); 
-            // InternalTestgeneratorDSL.g:2143:2: ( rule__BPMNDiagram__BpmnAssignment_7 )
-            // InternalTestgeneratorDSL.g:2143:3: rule__BPMNDiagram__BpmnAssignment_7
+            // InternalTestgeneratorDSL.g:2149:2: ( rule__BPMNDiagram__BpmnAssignment_7 )
+            // InternalTestgeneratorDSL.g:2149:3: rule__BPMNDiagram__BpmnAssignment_7
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__BpmnAssignment_7();
@@ -7122,14 +7147,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__8"
-    // InternalTestgeneratorDSL.g:2151:1: rule__BPMNDiagram__Group__8 : rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9 ;
+    // InternalTestgeneratorDSL.g:2157:1: rule__BPMNDiagram__Group__8 : rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9 ;
     public final void rule__BPMNDiagram__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2155:1: ( rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9 )
-            // InternalTestgeneratorDSL.g:2156:2: rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9
+            // InternalTestgeneratorDSL.g:2161:1: ( rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9 )
+            // InternalTestgeneratorDSL.g:2162:2: rule__BPMNDiagram__Group__8__Impl rule__BPMNDiagram__Group__9
             {
             pushFollow(FOLLOW_9);
             rule__BPMNDiagram__Group__8__Impl();
@@ -7160,20 +7185,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:2163:1: rule__BPMNDiagram__Group__8__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:2169:1: rule__BPMNDiagram__Group__8__Impl : ( 'with' ) ;
     public final void rule__BPMNDiagram__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2167:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:2168:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2173:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:2174:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:2168:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:2169:2: 'with'
+            // InternalTestgeneratorDSL.g:2174:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2175:2: 'with'
             {
              before(grammarAccess.getBPMNDiagramAccess().getWithKeyword_8()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getWithKeyword_8()); 
 
             }
@@ -7197,14 +7222,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__9"
-    // InternalTestgeneratorDSL.g:2178:1: rule__BPMNDiagram__Group__9 : rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10 ;
+    // InternalTestgeneratorDSL.g:2184:1: rule__BPMNDiagram__Group__9 : rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10 ;
     public final void rule__BPMNDiagram__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2182:1: ( rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10 )
-            // InternalTestgeneratorDSL.g:2183:2: rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10
+            // InternalTestgeneratorDSL.g:2188:1: ( rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10 )
+            // InternalTestgeneratorDSL.g:2189:2: rule__BPMNDiagram__Group__9__Impl rule__BPMNDiagram__Group__10
             {
             pushFollow(FOLLOW_7);
             rule__BPMNDiagram__Group__9__Impl();
@@ -7235,20 +7260,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:2190:1: rule__BPMNDiagram__Group__9__Impl : ( 'key' ) ;
+    // InternalTestgeneratorDSL.g:2196:1: rule__BPMNDiagram__Group__9__Impl : ( 'key' ) ;
     public final void rule__BPMNDiagram__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2194:1: ( ( 'key' ) )
-            // InternalTestgeneratorDSL.g:2195:1: ( 'key' )
+            // InternalTestgeneratorDSL.g:2200:1: ( ( 'key' ) )
+            // InternalTestgeneratorDSL.g:2201:1: ( 'key' )
             {
-            // InternalTestgeneratorDSL.g:2195:1: ( 'key' )
-            // InternalTestgeneratorDSL.g:2196:2: 'key'
+            // InternalTestgeneratorDSL.g:2201:1: ( 'key' )
+            // InternalTestgeneratorDSL.g:2202:2: 'key'
             {
              before(grammarAccess.getBPMNDiagramAccess().getKeyKeyword_9()); 
-            match(input,31,FOLLOW_2); 
+            match(input,32,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getKeyKeyword_9()); 
 
             }
@@ -7272,14 +7297,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__10"
-    // InternalTestgeneratorDSL.g:2205:1: rule__BPMNDiagram__Group__10 : rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11 ;
+    // InternalTestgeneratorDSL.g:2211:1: rule__BPMNDiagram__Group__10 : rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11 ;
     public final void rule__BPMNDiagram__Group__10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2209:1: ( rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11 )
-            // InternalTestgeneratorDSL.g:2210:2: rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11
+            // InternalTestgeneratorDSL.g:2215:1: ( rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11 )
+            // InternalTestgeneratorDSL.g:2216:2: rule__BPMNDiagram__Group__10__Impl rule__BPMNDiagram__Group__11
             {
             pushFollow(FOLLOW_10);
             rule__BPMNDiagram__Group__10__Impl();
@@ -7310,21 +7335,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__10__Impl"
-    // InternalTestgeneratorDSL.g:2217:1: rule__BPMNDiagram__Group__10__Impl : ( ( rule__BPMNDiagram__KeyAssignment_10 ) ) ;
+    // InternalTestgeneratorDSL.g:2223:1: rule__BPMNDiagram__Group__10__Impl : ( ( rule__BPMNDiagram__KeyAssignment_10 ) ) ;
     public final void rule__BPMNDiagram__Group__10__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2221:1: ( ( ( rule__BPMNDiagram__KeyAssignment_10 ) ) )
-            // InternalTestgeneratorDSL.g:2222:1: ( ( rule__BPMNDiagram__KeyAssignment_10 ) )
+            // InternalTestgeneratorDSL.g:2227:1: ( ( ( rule__BPMNDiagram__KeyAssignment_10 ) ) )
+            // InternalTestgeneratorDSL.g:2228:1: ( ( rule__BPMNDiagram__KeyAssignment_10 ) )
             {
-            // InternalTestgeneratorDSL.g:2222:1: ( ( rule__BPMNDiagram__KeyAssignment_10 ) )
-            // InternalTestgeneratorDSL.g:2223:2: ( rule__BPMNDiagram__KeyAssignment_10 )
+            // InternalTestgeneratorDSL.g:2228:1: ( ( rule__BPMNDiagram__KeyAssignment_10 ) )
+            // InternalTestgeneratorDSL.g:2229:2: ( rule__BPMNDiagram__KeyAssignment_10 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getKeyAssignment_10()); 
-            // InternalTestgeneratorDSL.g:2224:2: ( rule__BPMNDiagram__KeyAssignment_10 )
-            // InternalTestgeneratorDSL.g:2224:3: rule__BPMNDiagram__KeyAssignment_10
+            // InternalTestgeneratorDSL.g:2230:2: ( rule__BPMNDiagram__KeyAssignment_10 )
+            // InternalTestgeneratorDSL.g:2230:3: rule__BPMNDiagram__KeyAssignment_10
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__KeyAssignment_10();
@@ -7357,14 +7382,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__11"
-    // InternalTestgeneratorDSL.g:2232:1: rule__BPMNDiagram__Group__11 : rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12 ;
+    // InternalTestgeneratorDSL.g:2238:1: rule__BPMNDiagram__Group__11 : rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12 ;
     public final void rule__BPMNDiagram__Group__11() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2236:1: ( rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12 )
-            // InternalTestgeneratorDSL.g:2237:2: rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12
+            // InternalTestgeneratorDSL.g:2242:1: ( rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12 )
+            // InternalTestgeneratorDSL.g:2243:2: rule__BPMNDiagram__Group__11__Impl rule__BPMNDiagram__Group__12
             {
             pushFollow(FOLLOW_10);
             rule__BPMNDiagram__Group__11__Impl();
@@ -7395,33 +7420,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__11__Impl"
-    // InternalTestgeneratorDSL.g:2244:1: rule__BPMNDiagram__Group__11__Impl : ( ( rule__BPMNDiagram__Group_11__0 )? ) ;
+    // InternalTestgeneratorDSL.g:2250:1: rule__BPMNDiagram__Group__11__Impl : ( ( rule__BPMNDiagram__Group_11__0 )? ) ;
     public final void rule__BPMNDiagram__Group__11__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2248:1: ( ( ( rule__BPMNDiagram__Group_11__0 )? ) )
-            // InternalTestgeneratorDSL.g:2249:1: ( ( rule__BPMNDiagram__Group_11__0 )? )
+            // InternalTestgeneratorDSL.g:2254:1: ( ( ( rule__BPMNDiagram__Group_11__0 )? ) )
+            // InternalTestgeneratorDSL.g:2255:1: ( ( rule__BPMNDiagram__Group_11__0 )? )
             {
-            // InternalTestgeneratorDSL.g:2249:1: ( ( rule__BPMNDiagram__Group_11__0 )? )
-            // InternalTestgeneratorDSL.g:2250:2: ( rule__BPMNDiagram__Group_11__0 )?
+            // InternalTestgeneratorDSL.g:2255:1: ( ( rule__BPMNDiagram__Group_11__0 )? )
+            // InternalTestgeneratorDSL.g:2256:2: ( rule__BPMNDiagram__Group_11__0 )?
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_11()); 
-            // InternalTestgeneratorDSL.g:2251:2: ( rule__BPMNDiagram__Group_11__0 )?
+            // InternalTestgeneratorDSL.g:2257:2: ( rule__BPMNDiagram__Group_11__0 )?
             int alt17=2;
             int LA17_0 = input.LA(1);
 
-            if ( (LA17_0==28) ) {
+            if ( (LA17_0==29) ) {
                 int LA17_1 = input.LA(2);
 
-                if ( (LA17_1==32) ) {
+                if ( (LA17_1==33) ) {
                     alt17=1;
                 }
             }
             switch (alt17) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2251:3: rule__BPMNDiagram__Group_11__0
+                    // InternalTestgeneratorDSL.g:2257:3: rule__BPMNDiagram__Group_11__0
                     {
                     pushFollow(FOLLOW_2);
                     rule__BPMNDiagram__Group_11__0();
@@ -7457,14 +7482,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__12"
-    // InternalTestgeneratorDSL.g:2259:1: rule__BPMNDiagram__Group__12 : rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13 ;
+    // InternalTestgeneratorDSL.g:2265:1: rule__BPMNDiagram__Group__12 : rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13 ;
     public final void rule__BPMNDiagram__Group__12() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2263:1: ( rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13 )
-            // InternalTestgeneratorDSL.g:2264:2: rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13
+            // InternalTestgeneratorDSL.g:2269:1: ( rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13 )
+            // InternalTestgeneratorDSL.g:2270:2: rule__BPMNDiagram__Group__12__Impl rule__BPMNDiagram__Group__13
             {
             pushFollow(FOLLOW_10);
             rule__BPMNDiagram__Group__12__Impl();
@@ -7495,29 +7520,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__12__Impl"
-    // InternalTestgeneratorDSL.g:2271:1: rule__BPMNDiagram__Group__12__Impl : ( ( rule__BPMNDiagram__Group_12__0 )? ) ;
+    // InternalTestgeneratorDSL.g:2277:1: rule__BPMNDiagram__Group__12__Impl : ( ( rule__BPMNDiagram__Group_12__0 )? ) ;
     public final void rule__BPMNDiagram__Group__12__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2275:1: ( ( ( rule__BPMNDiagram__Group_12__0 )? ) )
-            // InternalTestgeneratorDSL.g:2276:1: ( ( rule__BPMNDiagram__Group_12__0 )? )
+            // InternalTestgeneratorDSL.g:2281:1: ( ( ( rule__BPMNDiagram__Group_12__0 )? ) )
+            // InternalTestgeneratorDSL.g:2282:1: ( ( rule__BPMNDiagram__Group_12__0 )? )
             {
-            // InternalTestgeneratorDSL.g:2276:1: ( ( rule__BPMNDiagram__Group_12__0 )? )
-            // InternalTestgeneratorDSL.g:2277:2: ( rule__BPMNDiagram__Group_12__0 )?
+            // InternalTestgeneratorDSL.g:2282:1: ( ( rule__BPMNDiagram__Group_12__0 )? )
+            // InternalTestgeneratorDSL.g:2283:2: ( rule__BPMNDiagram__Group_12__0 )?
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_12()); 
-            // InternalTestgeneratorDSL.g:2278:2: ( rule__BPMNDiagram__Group_12__0 )?
+            // InternalTestgeneratorDSL.g:2284:2: ( rule__BPMNDiagram__Group_12__0 )?
             int alt18=2;
             int LA18_0 = input.LA(1);
 
-            if ( (LA18_0==28) ) {
+            if ( (LA18_0==29) ) {
                 alt18=1;
             }
             switch (alt18) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2278:3: rule__BPMNDiagram__Group_12__0
+                    // InternalTestgeneratorDSL.g:2284:3: rule__BPMNDiagram__Group_12__0
                     {
                     pushFollow(FOLLOW_2);
                     rule__BPMNDiagram__Group_12__0();
@@ -7553,14 +7578,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__13"
-    // InternalTestgeneratorDSL.g:2286:1: rule__BPMNDiagram__Group__13 : rule__BPMNDiagram__Group__13__Impl ;
+    // InternalTestgeneratorDSL.g:2292:1: rule__BPMNDiagram__Group__13 : rule__BPMNDiagram__Group__13__Impl ;
     public final void rule__BPMNDiagram__Group__13() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2290:1: ( rule__BPMNDiagram__Group__13__Impl )
-            // InternalTestgeneratorDSL.g:2291:2: rule__BPMNDiagram__Group__13__Impl
+            // InternalTestgeneratorDSL.g:2296:1: ( rule__BPMNDiagram__Group__13__Impl )
+            // InternalTestgeneratorDSL.g:2297:2: rule__BPMNDiagram__Group__13__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group__13__Impl();
@@ -7586,17 +7611,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group__13__Impl"
-    // InternalTestgeneratorDSL.g:2297:1: rule__BPMNDiagram__Group__13__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2303:1: rule__BPMNDiagram__Group__13__Impl : ( RULE_DECLARATION_FINISHED ) ;
     public final void rule__BPMNDiagram__Group__13__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2301:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2302:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2307:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2308:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2302:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2303:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2308:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2309:2: RULE_DECLARATION_FINISHED
             {
              before(grammarAccess.getBPMNDiagramAccess().getDECLARATION_FINISHEDTerminalRuleCall_13()); 
             match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
@@ -7623,14 +7648,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__0"
-    // InternalTestgeneratorDSL.g:2313:1: rule__BPMNDiagram__Group_11__0 : rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1 ;
+    // InternalTestgeneratorDSL.g:2319:1: rule__BPMNDiagram__Group_11__0 : rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1 ;
     public final void rule__BPMNDiagram__Group_11__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2317:1: ( rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1 )
-            // InternalTestgeneratorDSL.g:2318:2: rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1
+            // InternalTestgeneratorDSL.g:2323:1: ( rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1 )
+            // InternalTestgeneratorDSL.g:2324:2: rule__BPMNDiagram__Group_11__0__Impl rule__BPMNDiagram__Group_11__1
             {
             pushFollow(FOLLOW_11);
             rule__BPMNDiagram__Group_11__0__Impl();
@@ -7661,20 +7686,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__0__Impl"
-    // InternalTestgeneratorDSL.g:2325:1: rule__BPMNDiagram__Group_11__0__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:2331:1: rule__BPMNDiagram__Group_11__0__Impl : ( 'with' ) ;
     public final void rule__BPMNDiagram__Group_11__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2329:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:2330:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2335:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:2336:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:2330:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:2331:2: 'with'
+            // InternalTestgeneratorDSL.g:2336:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2337:2: 'with'
             {
              before(grammarAccess.getBPMNDiagramAccess().getWithKeyword_11_0()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getWithKeyword_11_0()); 
 
             }
@@ -7698,14 +7723,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__1"
-    // InternalTestgeneratorDSL.g:2340:1: rule__BPMNDiagram__Group_11__1 : rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2 ;
+    // InternalTestgeneratorDSL.g:2346:1: rule__BPMNDiagram__Group_11__1 : rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2 ;
     public final void rule__BPMNDiagram__Group_11__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2344:1: ( rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2 )
-            // InternalTestgeneratorDSL.g:2345:2: rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2
+            // InternalTestgeneratorDSL.g:2350:1: ( rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2 )
+            // InternalTestgeneratorDSL.g:2351:2: rule__BPMNDiagram__Group_11__1__Impl rule__BPMNDiagram__Group_11__2
             {
             pushFollow(FOLLOW_12);
             rule__BPMNDiagram__Group_11__1__Impl();
@@ -7736,20 +7761,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__1__Impl"
-    // InternalTestgeneratorDSL.g:2352:1: rule__BPMNDiagram__Group_11__1__Impl : ( 'dmn' ) ;
+    // InternalTestgeneratorDSL.g:2358:1: rule__BPMNDiagram__Group_11__1__Impl : ( 'dmn' ) ;
     public final void rule__BPMNDiagram__Group_11__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2356:1: ( ( 'dmn' ) )
-            // InternalTestgeneratorDSL.g:2357:1: ( 'dmn' )
+            // InternalTestgeneratorDSL.g:2362:1: ( ( 'dmn' ) )
+            // InternalTestgeneratorDSL.g:2363:1: ( 'dmn' )
             {
-            // InternalTestgeneratorDSL.g:2357:1: ( 'dmn' )
-            // InternalTestgeneratorDSL.g:2358:2: 'dmn'
+            // InternalTestgeneratorDSL.g:2363:1: ( 'dmn' )
+            // InternalTestgeneratorDSL.g:2364:2: 'dmn'
             {
              before(grammarAccess.getBPMNDiagramAccess().getDmnKeyword_11_1()); 
-            match(input,32,FOLLOW_2); 
+            match(input,33,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getDmnKeyword_11_1()); 
 
             }
@@ -7773,14 +7798,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__2"
-    // InternalTestgeneratorDSL.g:2367:1: rule__BPMNDiagram__Group_11__2 : rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3 ;
+    // InternalTestgeneratorDSL.g:2373:1: rule__BPMNDiagram__Group_11__2 : rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3 ;
     public final void rule__BPMNDiagram__Group_11__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2371:1: ( rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3 )
-            // InternalTestgeneratorDSL.g:2372:2: rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3
+            // InternalTestgeneratorDSL.g:2377:1: ( rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3 )
+            // InternalTestgeneratorDSL.g:2378:2: rule__BPMNDiagram__Group_11__2__Impl rule__BPMNDiagram__Group_11__3
             {
             pushFollow(FOLLOW_13);
             rule__BPMNDiagram__Group_11__2__Impl();
@@ -7811,17 +7836,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__2__Impl"
-    // InternalTestgeneratorDSL.g:2379:1: rule__BPMNDiagram__Group_11__2__Impl : ( RULE_ASSOCIATION ) ;
+    // InternalTestgeneratorDSL.g:2385:1: rule__BPMNDiagram__Group_11__2__Impl : ( RULE_ASSOCIATION ) ;
     public final void rule__BPMNDiagram__Group_11__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2383:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:2384:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2389:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:2390:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:2384:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:2385:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:2390:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2391:2: RULE_ASSOCIATION
             {
              before(grammarAccess.getBPMNDiagramAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
@@ -7848,14 +7873,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__3"
-    // InternalTestgeneratorDSL.g:2394:1: rule__BPMNDiagram__Group_11__3 : rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4 ;
+    // InternalTestgeneratorDSL.g:2400:1: rule__BPMNDiagram__Group_11__3 : rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4 ;
     public final void rule__BPMNDiagram__Group_11__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2398:1: ( rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4 )
-            // InternalTestgeneratorDSL.g:2399:2: rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4
+            // InternalTestgeneratorDSL.g:2404:1: ( rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4 )
+            // InternalTestgeneratorDSL.g:2405:2: rule__BPMNDiagram__Group_11__3__Impl rule__BPMNDiagram__Group_11__4
             {
             pushFollow(FOLLOW_14);
             rule__BPMNDiagram__Group_11__3__Impl();
@@ -7886,17 +7911,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__3__Impl"
-    // InternalTestgeneratorDSL.g:2406:1: rule__BPMNDiagram__Group_11__3__Impl : ( RULE_LIST_OPEN ) ;
+    // InternalTestgeneratorDSL.g:2412:1: rule__BPMNDiagram__Group_11__3__Impl : ( RULE_LIST_OPEN ) ;
     public final void rule__BPMNDiagram__Group_11__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2410:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:2411:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:2416:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:2417:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:2411:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:2412:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:2417:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:2418:2: RULE_LIST_OPEN
             {
              before(grammarAccess.getBPMNDiagramAccess().getLIST_OPENTerminalRuleCall_11_3()); 
             match(input,RULE_LIST_OPEN,FOLLOW_2); 
@@ -7923,14 +7948,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__4"
-    // InternalTestgeneratorDSL.g:2421:1: rule__BPMNDiagram__Group_11__4 : rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5 ;
+    // InternalTestgeneratorDSL.g:2427:1: rule__BPMNDiagram__Group_11__4 : rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5 ;
     public final void rule__BPMNDiagram__Group_11__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2425:1: ( rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5 )
-            // InternalTestgeneratorDSL.g:2426:2: rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5
+            // InternalTestgeneratorDSL.g:2431:1: ( rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5 )
+            // InternalTestgeneratorDSL.g:2432:2: rule__BPMNDiagram__Group_11__4__Impl rule__BPMNDiagram__Group_11__5
             {
             pushFollow(FOLLOW_14);
             rule__BPMNDiagram__Group_11__4__Impl();
@@ -7961,20 +7986,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__4__Impl"
-    // InternalTestgeneratorDSL.g:2433:1: rule__BPMNDiagram__Group_11__4__Impl : ( ( rule__BPMNDiagram__Group_11_4__0 )? ) ;
+    // InternalTestgeneratorDSL.g:2439:1: rule__BPMNDiagram__Group_11__4__Impl : ( ( rule__BPMNDiagram__Group_11_4__0 )? ) ;
     public final void rule__BPMNDiagram__Group_11__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2437:1: ( ( ( rule__BPMNDiagram__Group_11_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:2438:1: ( ( rule__BPMNDiagram__Group_11_4__0 )? )
+            // InternalTestgeneratorDSL.g:2443:1: ( ( ( rule__BPMNDiagram__Group_11_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:2444:1: ( ( rule__BPMNDiagram__Group_11_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:2438:1: ( ( rule__BPMNDiagram__Group_11_4__0 )? )
-            // InternalTestgeneratorDSL.g:2439:2: ( rule__BPMNDiagram__Group_11_4__0 )?
+            // InternalTestgeneratorDSL.g:2444:1: ( ( rule__BPMNDiagram__Group_11_4__0 )? )
+            // InternalTestgeneratorDSL.g:2445:2: ( rule__BPMNDiagram__Group_11_4__0 )?
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_11_4()); 
-            // InternalTestgeneratorDSL.g:2440:2: ( rule__BPMNDiagram__Group_11_4__0 )?
+            // InternalTestgeneratorDSL.g:2446:2: ( rule__BPMNDiagram__Group_11_4__0 )?
             int alt19=2;
             int LA19_0 = input.LA(1);
 
@@ -7983,7 +8008,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             }
             switch (alt19) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2440:3: rule__BPMNDiagram__Group_11_4__0
+                    // InternalTestgeneratorDSL.g:2446:3: rule__BPMNDiagram__Group_11_4__0
                     {
                     pushFollow(FOLLOW_2);
                     rule__BPMNDiagram__Group_11_4__0();
@@ -8019,14 +8044,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__5"
-    // InternalTestgeneratorDSL.g:2448:1: rule__BPMNDiagram__Group_11__5 : rule__BPMNDiagram__Group_11__5__Impl ;
+    // InternalTestgeneratorDSL.g:2454:1: rule__BPMNDiagram__Group_11__5 : rule__BPMNDiagram__Group_11__5__Impl ;
     public final void rule__BPMNDiagram__Group_11__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2452:1: ( rule__BPMNDiagram__Group_11__5__Impl )
-            // InternalTestgeneratorDSL.g:2453:2: rule__BPMNDiagram__Group_11__5__Impl
+            // InternalTestgeneratorDSL.g:2458:1: ( rule__BPMNDiagram__Group_11__5__Impl )
+            // InternalTestgeneratorDSL.g:2459:2: rule__BPMNDiagram__Group_11__5__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_11__5__Impl();
@@ -8052,17 +8077,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11__5__Impl"
-    // InternalTestgeneratorDSL.g:2459:1: rule__BPMNDiagram__Group_11__5__Impl : ( RULE_LIST_CLOSED ) ;
+    // InternalTestgeneratorDSL.g:2465:1: rule__BPMNDiagram__Group_11__5__Impl : ( RULE_LIST_CLOSED ) ;
     public final void rule__BPMNDiagram__Group_11__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2463:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:2464:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2469:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:2470:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:2464:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:2465:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:2470:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2471:2: RULE_LIST_CLOSED
             {
              before(grammarAccess.getBPMNDiagramAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); 
             match(input,RULE_LIST_CLOSED,FOLLOW_2); 
@@ -8089,14 +8114,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4__0"
-    // InternalTestgeneratorDSL.g:2475:1: rule__BPMNDiagram__Group_11_4__0 : rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1 ;
+    // InternalTestgeneratorDSL.g:2481:1: rule__BPMNDiagram__Group_11_4__0 : rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1 ;
     public final void rule__BPMNDiagram__Group_11_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2479:1: ( rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1 )
-            // InternalTestgeneratorDSL.g:2480:2: rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1
+            // InternalTestgeneratorDSL.g:2485:1: ( rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1 )
+            // InternalTestgeneratorDSL.g:2486:2: rule__BPMNDiagram__Group_11_4__0__Impl rule__BPMNDiagram__Group_11_4__1
             {
             pushFollow(FOLLOW_15);
             rule__BPMNDiagram__Group_11_4__0__Impl();
@@ -8127,21 +8152,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4__0__Impl"
-    // InternalTestgeneratorDSL.g:2487:1: rule__BPMNDiagram__Group_11_4__0__Impl : ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) ) ;
+    // InternalTestgeneratorDSL.g:2493:1: rule__BPMNDiagram__Group_11_4__0__Impl : ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) ) ;
     public final void rule__BPMNDiagram__Group_11_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2491:1: ( ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:2492:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) )
+            // InternalTestgeneratorDSL.g:2497:1: ( ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:2498:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:2492:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) )
-            // InternalTestgeneratorDSL.g:2493:2: ( rule__BPMNDiagram__DmnAssignment_11_4_0 )
+            // InternalTestgeneratorDSL.g:2498:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_0 ) )
+            // InternalTestgeneratorDSL.g:2499:2: ( rule__BPMNDiagram__DmnAssignment_11_4_0 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getDmnAssignment_11_4_0()); 
-            // InternalTestgeneratorDSL.g:2494:2: ( rule__BPMNDiagram__DmnAssignment_11_4_0 )
-            // InternalTestgeneratorDSL.g:2494:3: rule__BPMNDiagram__DmnAssignment_11_4_0
+            // InternalTestgeneratorDSL.g:2500:2: ( rule__BPMNDiagram__DmnAssignment_11_4_0 )
+            // InternalTestgeneratorDSL.g:2500:3: rule__BPMNDiagram__DmnAssignment_11_4_0
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__DmnAssignment_11_4_0();
@@ -8174,14 +8199,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4__1"
-    // InternalTestgeneratorDSL.g:2502:1: rule__BPMNDiagram__Group_11_4__1 : rule__BPMNDiagram__Group_11_4__1__Impl ;
+    // InternalTestgeneratorDSL.g:2508:1: rule__BPMNDiagram__Group_11_4__1 : rule__BPMNDiagram__Group_11_4__1__Impl ;
     public final void rule__BPMNDiagram__Group_11_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2506:1: ( rule__BPMNDiagram__Group_11_4__1__Impl )
-            // InternalTestgeneratorDSL.g:2507:2: rule__BPMNDiagram__Group_11_4__1__Impl
+            // InternalTestgeneratorDSL.g:2512:1: ( rule__BPMNDiagram__Group_11_4__1__Impl )
+            // InternalTestgeneratorDSL.g:2513:2: rule__BPMNDiagram__Group_11_4__1__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_11_4__1__Impl();
@@ -8207,20 +8232,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4__1__Impl"
-    // InternalTestgeneratorDSL.g:2513:1: rule__BPMNDiagram__Group_11_4__1__Impl : ( ( rule__BPMNDiagram__Group_11_4_1__0 )* ) ;
+    // InternalTestgeneratorDSL.g:2519:1: rule__BPMNDiagram__Group_11_4__1__Impl : ( ( rule__BPMNDiagram__Group_11_4_1__0 )* ) ;
     public final void rule__BPMNDiagram__Group_11_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2517:1: ( ( ( rule__BPMNDiagram__Group_11_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:2518:1: ( ( rule__BPMNDiagram__Group_11_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:2523:1: ( ( ( rule__BPMNDiagram__Group_11_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:2524:1: ( ( rule__BPMNDiagram__Group_11_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:2518:1: ( ( rule__BPMNDiagram__Group_11_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:2519:2: ( rule__BPMNDiagram__Group_11_4_1__0 )*
+            // InternalTestgeneratorDSL.g:2524:1: ( ( rule__BPMNDiagram__Group_11_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:2525:2: ( rule__BPMNDiagram__Group_11_4_1__0 )*
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_11_4_1()); 
-            // InternalTestgeneratorDSL.g:2520:2: ( rule__BPMNDiagram__Group_11_4_1__0 )*
+            // InternalTestgeneratorDSL.g:2526:2: ( rule__BPMNDiagram__Group_11_4_1__0 )*
             loop20:
             do {
                 int alt20=2;
@@ -8233,7 +8258,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
                 switch (alt20) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:2520:3: rule__BPMNDiagram__Group_11_4_1__0
+            	    // InternalTestgeneratorDSL.g:2526:3: rule__BPMNDiagram__Group_11_4_1__0
             	    {
             	    pushFollow(FOLLOW_16);
             	    rule__BPMNDiagram__Group_11_4_1__0();
@@ -8272,14 +8297,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4_1__0"
-    // InternalTestgeneratorDSL.g:2529:1: rule__BPMNDiagram__Group_11_4_1__0 : rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1 ;
+    // InternalTestgeneratorDSL.g:2535:1: rule__BPMNDiagram__Group_11_4_1__0 : rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1 ;
     public final void rule__BPMNDiagram__Group_11_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2533:1: ( rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1 )
-            // InternalTestgeneratorDSL.g:2534:2: rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1
+            // InternalTestgeneratorDSL.g:2539:1: ( rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1 )
+            // InternalTestgeneratorDSL.g:2540:2: rule__BPMNDiagram__Group_11_4_1__0__Impl rule__BPMNDiagram__Group_11_4_1__1
             {
             pushFollow(FOLLOW_7);
             rule__BPMNDiagram__Group_11_4_1__0__Impl();
@@ -8310,17 +8335,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:2541:1: rule__BPMNDiagram__Group_11_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    // InternalTestgeneratorDSL.g:2547:1: rule__BPMNDiagram__Group_11_4_1__0__Impl : ( RULE_SEPARATOR ) ;
     public final void rule__BPMNDiagram__Group_11_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2545:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:2546:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:2551:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:2552:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:2546:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:2547:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:2552:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:2553:2: RULE_SEPARATOR
             {
              before(grammarAccess.getBPMNDiagramAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
@@ -8347,14 +8372,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4_1__1"
-    // InternalTestgeneratorDSL.g:2556:1: rule__BPMNDiagram__Group_11_4_1__1 : rule__BPMNDiagram__Group_11_4_1__1__Impl ;
+    // InternalTestgeneratorDSL.g:2562:1: rule__BPMNDiagram__Group_11_4_1__1 : rule__BPMNDiagram__Group_11_4_1__1__Impl ;
     public final void rule__BPMNDiagram__Group_11_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2560:1: ( rule__BPMNDiagram__Group_11_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:2561:2: rule__BPMNDiagram__Group_11_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:2566:1: ( rule__BPMNDiagram__Group_11_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:2567:2: rule__BPMNDiagram__Group_11_4_1__1__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_11_4_1__1__Impl();
@@ -8380,21 +8405,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_11_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:2567:1: rule__BPMNDiagram__Group_11_4_1__1__Impl : ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) ) ;
+    // InternalTestgeneratorDSL.g:2573:1: rule__BPMNDiagram__Group_11_4_1__1__Impl : ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) ) ;
     public final void rule__BPMNDiagram__Group_11_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2571:1: ( ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:2572:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:2577:1: ( ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:2578:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:2572:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:2573:2: ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 )
+            // InternalTestgeneratorDSL.g:2578:1: ( ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:2579:2: ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getDmnAssignment_11_4_1_1()); 
-            // InternalTestgeneratorDSL.g:2574:2: ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 )
-            // InternalTestgeneratorDSL.g:2574:3: rule__BPMNDiagram__DmnAssignment_11_4_1_1
+            // InternalTestgeneratorDSL.g:2580:2: ( rule__BPMNDiagram__DmnAssignment_11_4_1_1 )
+            // InternalTestgeneratorDSL.g:2580:3: rule__BPMNDiagram__DmnAssignment_11_4_1_1
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__DmnAssignment_11_4_1_1();
@@ -8427,14 +8452,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__0"
-    // InternalTestgeneratorDSL.g:2583:1: rule__BPMNDiagram__Group_12__0 : rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1 ;
+    // InternalTestgeneratorDSL.g:2589:1: rule__BPMNDiagram__Group_12__0 : rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1 ;
     public final void rule__BPMNDiagram__Group_12__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2587:1: ( rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1 )
-            // InternalTestgeneratorDSL.g:2588:2: rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1
+            // InternalTestgeneratorDSL.g:2593:1: ( rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1 )
+            // InternalTestgeneratorDSL.g:2594:2: rule__BPMNDiagram__Group_12__0__Impl rule__BPMNDiagram__Group_12__1
             {
             pushFollow(FOLLOW_17);
             rule__BPMNDiagram__Group_12__0__Impl();
@@ -8465,20 +8490,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__0__Impl"
-    // InternalTestgeneratorDSL.g:2595:1: rule__BPMNDiagram__Group_12__0__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:2601:1: rule__BPMNDiagram__Group_12__0__Impl : ( 'with' ) ;
     public final void rule__BPMNDiagram__Group_12__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2599:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:2600:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2605:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:2606:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:2600:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:2601:2: 'with'
+            // InternalTestgeneratorDSL.g:2606:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:2607:2: 'with'
             {
              before(grammarAccess.getBPMNDiagramAccess().getWithKeyword_12_0()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getWithKeyword_12_0()); 
 
             }
@@ -8502,14 +8527,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__1"
-    // InternalTestgeneratorDSL.g:2610:1: rule__BPMNDiagram__Group_12__1 : rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2 ;
+    // InternalTestgeneratorDSL.g:2616:1: rule__BPMNDiagram__Group_12__1 : rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2 ;
     public final void rule__BPMNDiagram__Group_12__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2614:1: ( rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2 )
-            // InternalTestgeneratorDSL.g:2615:2: rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2
+            // InternalTestgeneratorDSL.g:2620:1: ( rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2 )
+            // InternalTestgeneratorDSL.g:2621:2: rule__BPMNDiagram__Group_12__1__Impl rule__BPMNDiagram__Group_12__2
             {
             pushFollow(FOLLOW_12);
             rule__BPMNDiagram__Group_12__1__Impl();
@@ -8540,20 +8565,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__1__Impl"
-    // InternalTestgeneratorDSL.g:2622:1: rule__BPMNDiagram__Group_12__1__Impl : ( 'embedded' ) ;
+    // InternalTestgeneratorDSL.g:2628:1: rule__BPMNDiagram__Group_12__1__Impl : ( 'embedded' ) ;
     public final void rule__BPMNDiagram__Group_12__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2626:1: ( ( 'embedded' ) )
-            // InternalTestgeneratorDSL.g:2627:1: ( 'embedded' )
+            // InternalTestgeneratorDSL.g:2632:1: ( ( 'embedded' ) )
+            // InternalTestgeneratorDSL.g:2633:1: ( 'embedded' )
             {
-            // InternalTestgeneratorDSL.g:2627:1: ( 'embedded' )
-            // InternalTestgeneratorDSL.g:2628:2: 'embedded'
+            // InternalTestgeneratorDSL.g:2633:1: ( 'embedded' )
+            // InternalTestgeneratorDSL.g:2634:2: 'embedded'
             {
              before(grammarAccess.getBPMNDiagramAccess().getEmbeddedKeyword_12_1()); 
-            match(input,33,FOLLOW_2); 
+            match(input,34,FOLLOW_2); 
              after(grammarAccess.getBPMNDiagramAccess().getEmbeddedKeyword_12_1()); 
 
             }
@@ -8577,14 +8602,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__2"
-    // InternalTestgeneratorDSL.g:2637:1: rule__BPMNDiagram__Group_12__2 : rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3 ;
+    // InternalTestgeneratorDSL.g:2643:1: rule__BPMNDiagram__Group_12__2 : rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3 ;
     public final void rule__BPMNDiagram__Group_12__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2641:1: ( rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3 )
-            // InternalTestgeneratorDSL.g:2642:2: rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3
+            // InternalTestgeneratorDSL.g:2647:1: ( rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3 )
+            // InternalTestgeneratorDSL.g:2648:2: rule__BPMNDiagram__Group_12__2__Impl rule__BPMNDiagram__Group_12__3
             {
             pushFollow(FOLLOW_13);
             rule__BPMNDiagram__Group_12__2__Impl();
@@ -8615,17 +8640,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__2__Impl"
-    // InternalTestgeneratorDSL.g:2649:1: rule__BPMNDiagram__Group_12__2__Impl : ( RULE_ASSOCIATION ) ;
+    // InternalTestgeneratorDSL.g:2655:1: rule__BPMNDiagram__Group_12__2__Impl : ( RULE_ASSOCIATION ) ;
     public final void rule__BPMNDiagram__Group_12__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2653:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:2654:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2659:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:2660:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:2654:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:2655:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:2660:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2661:2: RULE_ASSOCIATION
             {
              before(grammarAccess.getBPMNDiagramAccess().getASSOCIATIONTerminalRuleCall_12_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
@@ -8652,14 +8677,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__3"
-    // InternalTestgeneratorDSL.g:2664:1: rule__BPMNDiagram__Group_12__3 : rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4 ;
+    // InternalTestgeneratorDSL.g:2670:1: rule__BPMNDiagram__Group_12__3 : rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4 ;
     public final void rule__BPMNDiagram__Group_12__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2668:1: ( rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4 )
-            // InternalTestgeneratorDSL.g:2669:2: rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4
+            // InternalTestgeneratorDSL.g:2674:1: ( rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4 )
+            // InternalTestgeneratorDSL.g:2675:2: rule__BPMNDiagram__Group_12__3__Impl rule__BPMNDiagram__Group_12__4
             {
             pushFollow(FOLLOW_14);
             rule__BPMNDiagram__Group_12__3__Impl();
@@ -8690,17 +8715,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__3__Impl"
-    // InternalTestgeneratorDSL.g:2676:1: rule__BPMNDiagram__Group_12__3__Impl : ( RULE_LIST_OPEN ) ;
+    // InternalTestgeneratorDSL.g:2682:1: rule__BPMNDiagram__Group_12__3__Impl : ( RULE_LIST_OPEN ) ;
     public final void rule__BPMNDiagram__Group_12__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2680:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:2681:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:2686:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:2687:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:2681:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:2682:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:2687:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:2688:2: RULE_LIST_OPEN
             {
              before(grammarAccess.getBPMNDiagramAccess().getLIST_OPENTerminalRuleCall_12_3()); 
             match(input,RULE_LIST_OPEN,FOLLOW_2); 
@@ -8727,14 +8752,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__4"
-    // InternalTestgeneratorDSL.g:2691:1: rule__BPMNDiagram__Group_12__4 : rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5 ;
+    // InternalTestgeneratorDSL.g:2697:1: rule__BPMNDiagram__Group_12__4 : rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5 ;
     public final void rule__BPMNDiagram__Group_12__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2695:1: ( rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5 )
-            // InternalTestgeneratorDSL.g:2696:2: rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5
+            // InternalTestgeneratorDSL.g:2701:1: ( rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5 )
+            // InternalTestgeneratorDSL.g:2702:2: rule__BPMNDiagram__Group_12__4__Impl rule__BPMNDiagram__Group_12__5
             {
             pushFollow(FOLLOW_14);
             rule__BPMNDiagram__Group_12__4__Impl();
@@ -8765,20 +8790,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__4__Impl"
-    // InternalTestgeneratorDSL.g:2703:1: rule__BPMNDiagram__Group_12__4__Impl : ( ( rule__BPMNDiagram__Group_12_4__0 )? ) ;
+    // InternalTestgeneratorDSL.g:2709:1: rule__BPMNDiagram__Group_12__4__Impl : ( ( rule__BPMNDiagram__Group_12_4__0 )? ) ;
     public final void rule__BPMNDiagram__Group_12__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2707:1: ( ( ( rule__BPMNDiagram__Group_12_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:2708:1: ( ( rule__BPMNDiagram__Group_12_4__0 )? )
+            // InternalTestgeneratorDSL.g:2713:1: ( ( ( rule__BPMNDiagram__Group_12_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:2714:1: ( ( rule__BPMNDiagram__Group_12_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:2708:1: ( ( rule__BPMNDiagram__Group_12_4__0 )? )
-            // InternalTestgeneratorDSL.g:2709:2: ( rule__BPMNDiagram__Group_12_4__0 )?
+            // InternalTestgeneratorDSL.g:2714:1: ( ( rule__BPMNDiagram__Group_12_4__0 )? )
+            // InternalTestgeneratorDSL.g:2715:2: ( rule__BPMNDiagram__Group_12_4__0 )?
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_12_4()); 
-            // InternalTestgeneratorDSL.g:2710:2: ( rule__BPMNDiagram__Group_12_4__0 )?
+            // InternalTestgeneratorDSL.g:2716:2: ( rule__BPMNDiagram__Group_12_4__0 )?
             int alt21=2;
             int LA21_0 = input.LA(1);
 
@@ -8787,7 +8812,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             }
             switch (alt21) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2710:3: rule__BPMNDiagram__Group_12_4__0
+                    // InternalTestgeneratorDSL.g:2716:3: rule__BPMNDiagram__Group_12_4__0
                     {
                     pushFollow(FOLLOW_2);
                     rule__BPMNDiagram__Group_12_4__0();
@@ -8823,14 +8848,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__5"
-    // InternalTestgeneratorDSL.g:2718:1: rule__BPMNDiagram__Group_12__5 : rule__BPMNDiagram__Group_12__5__Impl ;
+    // InternalTestgeneratorDSL.g:2724:1: rule__BPMNDiagram__Group_12__5 : rule__BPMNDiagram__Group_12__5__Impl ;
     public final void rule__BPMNDiagram__Group_12__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2722:1: ( rule__BPMNDiagram__Group_12__5__Impl )
-            // InternalTestgeneratorDSL.g:2723:2: rule__BPMNDiagram__Group_12__5__Impl
+            // InternalTestgeneratorDSL.g:2728:1: ( rule__BPMNDiagram__Group_12__5__Impl )
+            // InternalTestgeneratorDSL.g:2729:2: rule__BPMNDiagram__Group_12__5__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_12__5__Impl();
@@ -8856,17 +8881,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12__5__Impl"
-    // InternalTestgeneratorDSL.g:2729:1: rule__BPMNDiagram__Group_12__5__Impl : ( RULE_LIST_CLOSED ) ;
+    // InternalTestgeneratorDSL.g:2735:1: rule__BPMNDiagram__Group_12__5__Impl : ( RULE_LIST_CLOSED ) ;
     public final void rule__BPMNDiagram__Group_12__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2733:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:2734:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2739:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:2740:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:2734:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:2735:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:2740:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2741:2: RULE_LIST_CLOSED
             {
              before(grammarAccess.getBPMNDiagramAccess().getLIST_CLOSEDTerminalRuleCall_12_5()); 
             match(input,RULE_LIST_CLOSED,FOLLOW_2); 
@@ -8893,14 +8918,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4__0"
-    // InternalTestgeneratorDSL.g:2745:1: rule__BPMNDiagram__Group_12_4__0 : rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1 ;
+    // InternalTestgeneratorDSL.g:2751:1: rule__BPMNDiagram__Group_12_4__0 : rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1 ;
     public final void rule__BPMNDiagram__Group_12_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2749:1: ( rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1 )
-            // InternalTestgeneratorDSL.g:2750:2: rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1
+            // InternalTestgeneratorDSL.g:2755:1: ( rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1 )
+            // InternalTestgeneratorDSL.g:2756:2: rule__BPMNDiagram__Group_12_4__0__Impl rule__BPMNDiagram__Group_12_4__1
             {
             pushFollow(FOLLOW_15);
             rule__BPMNDiagram__Group_12_4__0__Impl();
@@ -8931,21 +8956,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4__0__Impl"
-    // InternalTestgeneratorDSL.g:2757:1: rule__BPMNDiagram__Group_12_4__0__Impl : ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) ) ;
+    // InternalTestgeneratorDSL.g:2763:1: rule__BPMNDiagram__Group_12_4__0__Impl : ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) ) ;
     public final void rule__BPMNDiagram__Group_12_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2761:1: ( ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:2762:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) )
+            // InternalTestgeneratorDSL.g:2767:1: ( ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:2768:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:2762:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) )
-            // InternalTestgeneratorDSL.g:2763:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 )
+            // InternalTestgeneratorDSL.g:2768:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 ) )
+            // InternalTestgeneratorDSL.g:2769:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getEmbeddedAssignment_12_4_0()); 
-            // InternalTestgeneratorDSL.g:2764:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 )
-            // InternalTestgeneratorDSL.g:2764:3: rule__BPMNDiagram__EmbeddedAssignment_12_4_0
+            // InternalTestgeneratorDSL.g:2770:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_0 )
+            // InternalTestgeneratorDSL.g:2770:3: rule__BPMNDiagram__EmbeddedAssignment_12_4_0
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__EmbeddedAssignment_12_4_0();
@@ -8978,14 +9003,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4__1"
-    // InternalTestgeneratorDSL.g:2772:1: rule__BPMNDiagram__Group_12_4__1 : rule__BPMNDiagram__Group_12_4__1__Impl ;
+    // InternalTestgeneratorDSL.g:2778:1: rule__BPMNDiagram__Group_12_4__1 : rule__BPMNDiagram__Group_12_4__1__Impl ;
     public final void rule__BPMNDiagram__Group_12_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2776:1: ( rule__BPMNDiagram__Group_12_4__1__Impl )
-            // InternalTestgeneratorDSL.g:2777:2: rule__BPMNDiagram__Group_12_4__1__Impl
+            // InternalTestgeneratorDSL.g:2782:1: ( rule__BPMNDiagram__Group_12_4__1__Impl )
+            // InternalTestgeneratorDSL.g:2783:2: rule__BPMNDiagram__Group_12_4__1__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_12_4__1__Impl();
@@ -9011,20 +9036,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4__1__Impl"
-    // InternalTestgeneratorDSL.g:2783:1: rule__BPMNDiagram__Group_12_4__1__Impl : ( ( rule__BPMNDiagram__Group_12_4_1__0 )* ) ;
+    // InternalTestgeneratorDSL.g:2789:1: rule__BPMNDiagram__Group_12_4__1__Impl : ( ( rule__BPMNDiagram__Group_12_4_1__0 )* ) ;
     public final void rule__BPMNDiagram__Group_12_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2787:1: ( ( ( rule__BPMNDiagram__Group_12_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:2788:1: ( ( rule__BPMNDiagram__Group_12_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:2793:1: ( ( ( rule__BPMNDiagram__Group_12_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:2794:1: ( ( rule__BPMNDiagram__Group_12_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:2788:1: ( ( rule__BPMNDiagram__Group_12_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:2789:2: ( rule__BPMNDiagram__Group_12_4_1__0 )*
+            // InternalTestgeneratorDSL.g:2794:1: ( ( rule__BPMNDiagram__Group_12_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:2795:2: ( rule__BPMNDiagram__Group_12_4_1__0 )*
             {
              before(grammarAccess.getBPMNDiagramAccess().getGroup_12_4_1()); 
-            // InternalTestgeneratorDSL.g:2790:2: ( rule__BPMNDiagram__Group_12_4_1__0 )*
+            // InternalTestgeneratorDSL.g:2796:2: ( rule__BPMNDiagram__Group_12_4_1__0 )*
             loop22:
             do {
                 int alt22=2;
@@ -9037,7 +9062,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
                 switch (alt22) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:2790:3: rule__BPMNDiagram__Group_12_4_1__0
+            	    // InternalTestgeneratorDSL.g:2796:3: rule__BPMNDiagram__Group_12_4_1__0
             	    {
             	    pushFollow(FOLLOW_16);
             	    rule__BPMNDiagram__Group_12_4_1__0();
@@ -9076,14 +9101,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4_1__0"
-    // InternalTestgeneratorDSL.g:2799:1: rule__BPMNDiagram__Group_12_4_1__0 : rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1 ;
+    // InternalTestgeneratorDSL.g:2805:1: rule__BPMNDiagram__Group_12_4_1__0 : rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1 ;
     public final void rule__BPMNDiagram__Group_12_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2803:1: ( rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1 )
-            // InternalTestgeneratorDSL.g:2804:2: rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1
+            // InternalTestgeneratorDSL.g:2809:1: ( rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1 )
+            // InternalTestgeneratorDSL.g:2810:2: rule__BPMNDiagram__Group_12_4_1__0__Impl rule__BPMNDiagram__Group_12_4_1__1
             {
             pushFollow(FOLLOW_7);
             rule__BPMNDiagram__Group_12_4_1__0__Impl();
@@ -9114,17 +9139,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:2811:1: rule__BPMNDiagram__Group_12_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    // InternalTestgeneratorDSL.g:2817:1: rule__BPMNDiagram__Group_12_4_1__0__Impl : ( RULE_SEPARATOR ) ;
     public final void rule__BPMNDiagram__Group_12_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2815:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:2816:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:2821:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:2822:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:2816:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:2817:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:2822:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:2823:2: RULE_SEPARATOR
             {
              before(grammarAccess.getBPMNDiagramAccess().getSEPARATORTerminalRuleCall_12_4_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
@@ -9151,14 +9176,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4_1__1"
-    // InternalTestgeneratorDSL.g:2826:1: rule__BPMNDiagram__Group_12_4_1__1 : rule__BPMNDiagram__Group_12_4_1__1__Impl ;
+    // InternalTestgeneratorDSL.g:2832:1: rule__BPMNDiagram__Group_12_4_1__1 : rule__BPMNDiagram__Group_12_4_1__1__Impl ;
     public final void rule__BPMNDiagram__Group_12_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2830:1: ( rule__BPMNDiagram__Group_12_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:2831:2: rule__BPMNDiagram__Group_12_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:2836:1: ( rule__BPMNDiagram__Group_12_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:2837:2: rule__BPMNDiagram__Group_12_4_1__1__Impl
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__Group_12_4_1__1__Impl();
@@ -9184,21 +9209,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BPMNDiagram__Group_12_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:2837:1: rule__BPMNDiagram__Group_12_4_1__1__Impl : ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) ) ;
+    // InternalTestgeneratorDSL.g:2843:1: rule__BPMNDiagram__Group_12_4_1__1__Impl : ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) ) ;
     public final void rule__BPMNDiagram__Group_12_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2841:1: ( ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:2842:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:2847:1: ( ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:2848:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:2842:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:2843:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 )
+            // InternalTestgeneratorDSL.g:2848:1: ( ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:2849:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 )
             {
              before(grammarAccess.getBPMNDiagramAccess().getEmbeddedAssignment_12_4_1_1()); 
-            // InternalTestgeneratorDSL.g:2844:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 )
-            // InternalTestgeneratorDSL.g:2844:3: rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1
+            // InternalTestgeneratorDSL.g:2850:2: ( rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 )
+            // InternalTestgeneratorDSL.g:2850:3: rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1
             {
             pushFollow(FOLLOW_2);
             rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1();
@@ -9231,14 +9256,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:2853:1: rule__StartFlowElement__Group__0 : rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1 ;
+    // InternalTestgeneratorDSL.g:2859:1: rule__StartFlowElement__Group__0 : rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1 ;
     public final void rule__StartFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2857:1: ( rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:2858:2: rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:2863:1: ( rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:2864:2: rule__StartFlowElement__Group__0__Impl rule__StartFlowElement__Group__1
             {
             pushFollow(FOLLOW_4);
             rule__StartFlowElement__Group__0__Impl();
@@ -9269,20 +9294,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:2865:1: rule__StartFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    // InternalTestgeneratorDSL.g:2871:1: rule__StartFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
     public final void rule__StartFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2869:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:2870:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:2875:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:2876:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:2870:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:2871:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:2876:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:2877:2: 'FlowElement'
             {
              before(grammarAccess.getStartFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
+            match(input,35,FOLLOW_2); 
              after(grammarAccess.getStartFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
@@ -9306,14 +9331,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:2880:1: rule__StartFlowElement__Group__1 : rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2 ;
+    // InternalTestgeneratorDSL.g:2886:1: rule__StartFlowElement__Group__1 : rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2 ;
     public final void rule__StartFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2884:1: ( rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:2885:2: rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:2890:1: ( rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:2891:2: rule__StartFlowElement__Group__1__Impl rule__StartFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
             rule__StartFlowElement__Group__1__Impl();
@@ -9344,21 +9369,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:2892:1: rule__StartFlowElement__Group__1__Impl : ( ( rule__StartFlowElement__NameAssignment_1 ) ) ;
+    // InternalTestgeneratorDSL.g:2898:1: rule__StartFlowElement__Group__1__Impl : ( ( rule__StartFlowElement__NameAssignment_1 ) ) ;
     public final void rule__StartFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2896:1: ( ( ( rule__StartFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:2897:1: ( ( rule__StartFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:2902:1: ( ( ( rule__StartFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:2903:1: ( ( rule__StartFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:2897:1: ( ( rule__StartFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:2898:2: ( rule__StartFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:2903:1: ( ( rule__StartFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:2904:2: ( rule__StartFlowElement__NameAssignment_1 )
             {
              before(grammarAccess.getStartFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:2899:2: ( rule__StartFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:2899:3: rule__StartFlowElement__NameAssignment_1
+            // InternalTestgeneratorDSL.g:2905:2: ( rule__StartFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:2905:3: rule__StartFlowElement__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
             rule__StartFlowElement__NameAssignment_1();
@@ -9391,14 +9416,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:2907:1: rule__StartFlowElement__Group__2 : rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3 ;
+    // InternalTestgeneratorDSL.g:2913:1: rule__StartFlowElement__Group__2 : rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3 ;
     public final void rule__StartFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2911:1: ( rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:2912:2: rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:2917:1: ( rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:2918:2: rule__StartFlowElement__Group__2__Impl rule__StartFlowElement__Group__3
             {
             pushFollow(FOLLOW_18);
             rule__StartFlowElement__Group__2__Impl();
@@ -9429,17 +9454,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:2919:1: rule__StartFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    // InternalTestgeneratorDSL.g:2925:1: rule__StartFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
     public final void rule__StartFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2923:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:2924:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2929:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:2930:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:2924:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:2925:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:2930:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:2931:2: RULE_ASSOCIATION
             {
              before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
@@ -9466,14 +9491,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:2934:1: rule__StartFlowElement__Group__3 : rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4 ;
+    // InternalTestgeneratorDSL.g:2940:1: rule__StartFlowElement__Group__3 : rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4 ;
     public final void rule__StartFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2938:1: ( rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:2939:2: rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:2944:1: ( rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:2945:2: rule__StartFlowElement__Group__3__Impl rule__StartFlowElement__Group__4
             {
             pushFollow(FOLLOW_10);
             rule__StartFlowElement__Group__3__Impl();
@@ -9504,20 +9529,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:2946:1: rule__StartFlowElement__Group__3__Impl : ( 'StartEvent' ) ;
+    // InternalTestgeneratorDSL.g:2952:1: rule__StartFlowElement__Group__3__Impl : ( 'StartEvent' ) ;
     public final void rule__StartFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2950:1: ( ( 'StartEvent' ) )
-            // InternalTestgeneratorDSL.g:2951:1: ( 'StartEvent' )
+            // InternalTestgeneratorDSL.g:2956:1: ( ( 'StartEvent' ) )
+            // InternalTestgeneratorDSL.g:2957:1: ( 'StartEvent' )
             {
-            // InternalTestgeneratorDSL.g:2951:1: ( 'StartEvent' )
-            // InternalTestgeneratorDSL.g:2952:2: 'StartEvent'
+            // InternalTestgeneratorDSL.g:2957:1: ( 'StartEvent' )
+            // InternalTestgeneratorDSL.g:2958:2: 'StartEvent'
             {
              before(grammarAccess.getStartFlowElementAccess().getStartEventKeyword_3()); 
-            match(input,35,FOLLOW_2); 
+            match(input,36,FOLLOW_2); 
              after(grammarAccess.getStartFlowElementAccess().getStartEventKeyword_3()); 
 
             }
@@ -9541,14 +9566,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:2961:1: rule__StartFlowElement__Group__4 : rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5 ;
+    // InternalTestgeneratorDSL.g:2967:1: rule__StartFlowElement__Group__4 : rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5 ;
     public final void rule__StartFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2965:1: ( rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:2966:2: rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:2971:1: ( rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:2972:2: rule__StartFlowElement__Group__4__Impl rule__StartFlowElement__Group__5
             {
             pushFollow(FOLLOW_10);
             rule__StartFlowElement__Group__4__Impl();
@@ -9579,33 +9604,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:2973:1: rule__StartFlowElement__Group__4__Impl : ( ( rule__StartFlowElement__Group_4__0 )? ) ;
+    // InternalTestgeneratorDSL.g:2979:1: rule__StartFlowElement__Group__4__Impl : ( ( rule__StartFlowElement__Group_4__0 )? ) ;
     public final void rule__StartFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2977:1: ( ( ( rule__StartFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:2978:1: ( ( rule__StartFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:2983:1: ( ( ( rule__StartFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:2984:1: ( ( rule__StartFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:2978:1: ( ( rule__StartFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:2979:2: ( rule__StartFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:2984:1: ( ( rule__StartFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:2985:2: ( rule__StartFlowElement__Group_4__0 )?
             {
              before(grammarAccess.getStartFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:2980:2: ( rule__StartFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:2986:2: ( rule__StartFlowElement__Group_4__0 )?
             int alt23=2;
             int LA23_0 = input.LA(1);
 
-            if ( (LA23_0==28) ) {
-                int LA23_1 = input.LA(2);
-
-                if ( (LA23_1==36) ) {
-                    alt23=1;
-                }
+            if ( (LA23_0==29) ) {
+                alt23=1;
             }
             switch (alt23) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2980:3: rule__StartFlowElement__Group_4__0
+                    // InternalTestgeneratorDSL.g:2986:3: rule__StartFlowElement__Group_4__0
                     {
                     pushFollow(FOLLOW_2);
                     rule__StartFlowElement__Group_4__0();
@@ -9641,22 +9662,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:2988:1: rule__StartFlowElement__Group__5 : rule__StartFlowElement__Group__5__Impl rule__StartFlowElement__Group__6 ;
+    // InternalTestgeneratorDSL.g:2994:1: rule__StartFlowElement__Group__5 : rule__StartFlowElement__Group__5__Impl ;
     public final void rule__StartFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:2992:1: ( rule__StartFlowElement__Group__5__Impl rule__StartFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:2993:2: rule__StartFlowElement__Group__5__Impl rule__StartFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:2998:1: ( rule__StartFlowElement__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:2999:2: rule__StartFlowElement__Group__5__Impl
             {
-            pushFollow(FOLLOW_10);
-            rule__StartFlowElement__Group__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group__6();
+            rule__StartFlowElement__Group__5__Impl();
 
             state._fsp--;
 
@@ -9679,112 +9695,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:3000:1: rule__StartFlowElement__Group__5__Impl : ( ( rule__StartFlowElement__Group_5__0 )? ) ;
+    // InternalTestgeneratorDSL.g:3005:1: rule__StartFlowElement__Group__5__Impl : ( RULE_DECLARATION_FINISHED ) ;
     public final void rule__StartFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3004:1: ( ( ( rule__StartFlowElement__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:3005:1: ( ( rule__StartFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:3009:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:3010:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3005:1: ( ( rule__StartFlowElement__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:3006:2: ( rule__StartFlowElement__Group_5__0 )?
+            // InternalTestgeneratorDSL.g:3010:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3011:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getStartFlowElementAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:3007:2: ( rule__StartFlowElement__Group_5__0 )?
-            int alt24=2;
-            int LA24_0 = input.LA(1);
-
-            if ( (LA24_0==28) ) {
-                alt24=1;
-            }
-            switch (alt24) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3007:3: rule__StartFlowElement__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__StartFlowElement__Group_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getStartFlowElementAccess().getGroup_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StartFlowElement__Group__5__Impl"
-
-
-    // $ANTLR start "rule__StartFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:3015:1: rule__StartFlowElement__Group__6 : rule__StartFlowElement__Group__6__Impl ;
-    public final void rule__StartFlowElement__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:3019:1: ( rule__StartFlowElement__Group__6__Impl )
-            // InternalTestgeneratorDSL.g:3020:2: rule__StartFlowElement__Group__6__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group__6__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StartFlowElement__Group__6"
-
-
-    // $ANTLR start "rule__StartFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:3026:1: rule__StartFlowElement__Group__6__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__StartFlowElement__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:3030:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3031:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:3031:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3032:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
+             before(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
             match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
+             after(grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
 
             }
 
@@ -9803,18 +9728,18 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__StartFlowElement__Group__5__Impl"
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:3042:1: rule__StartFlowElement__Group_4__0 : rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1 ;
+    // InternalTestgeneratorDSL.g:3021:1: rule__StartFlowElement__Group_4__0 : rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1 ;
     public final void rule__StartFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3046:1: ( rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:3047:2: rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1
+            // InternalTestgeneratorDSL.g:3025:1: ( rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:3026:2: rule__StartFlowElement__Group_4__0__Impl rule__StartFlowElement__Group_4__1
             {
             pushFollow(FOLLOW_19);
             rule__StartFlowElement__Group_4__0__Impl();
@@ -9845,20 +9770,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:3054:1: rule__StartFlowElement__Group_4__0__Impl : ( 'with' ) ;
+    // InternalTestgeneratorDSL.g:3033:1: rule__StartFlowElement__Group_4__0__Impl : ( 'with' ) ;
     public final void rule__StartFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3058:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:3059:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:3037:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:3038:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:3059:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:3060:2: 'with'
+            // InternalTestgeneratorDSL.g:3038:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:3039:2: 'with'
             {
              before(grammarAccess.getStartFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
+            match(input,29,FOLLOW_2); 
              after(grammarAccess.getStartFlowElementAccess().getWithKeyword_4_0()); 
 
             }
@@ -9882,16 +9807,16 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:3069:1: rule__StartFlowElement__Group_4__1 : rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2 ;
+    // InternalTestgeneratorDSL.g:3048:1: rule__StartFlowElement__Group_4__1 : rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2 ;
     public final void rule__StartFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3073:1: ( rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:3074:2: rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:3052:1: ( rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:3053:2: rule__StartFlowElement__Group_4__1__Impl rule__StartFlowElement__Group_4__2
             {
-            pushFollow(FOLLOW_20);
+            pushFollow(FOLLOW_12);
             rule__StartFlowElement__Group_4__1__Impl();
 
             state._fsp--;
@@ -9920,21 +9845,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:3081:1: rule__StartFlowElement__Group_4__1__Impl : ( 'hardcoded' ) ;
+    // InternalTestgeneratorDSL.g:3060:1: rule__StartFlowElement__Group_4__1__Impl : ( 'inputVariables' ) ;
     public final void rule__StartFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3085:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:3086:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:3064:1: ( ( 'inputVariables' ) )
+            // InternalTestgeneratorDSL.g:3065:1: ( 'inputVariables' )
             {
-            // InternalTestgeneratorDSL.g:3086:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:3087:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:3065:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:3066:2: 'inputVariables'
             {
-             before(grammarAccess.getStartFlowElementAccess().getHardcodedKeyword_4_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getHardcodedKeyword_4_1()); 
+             before(grammarAccess.getStartFlowElementAccess().getInputVariablesKeyword_4_1()); 
+            match(input,37,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getInputVariablesKeyword_4_1()); 
 
             }
 
@@ -9957,16 +9882,16 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:3096:1: rule__StartFlowElement__Group_4__2 : rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3 ;
+    // InternalTestgeneratorDSL.g:3075:1: rule__StartFlowElement__Group_4__2 : rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3 ;
     public final void rule__StartFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3100:1: ( rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:3101:2: rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:3079:1: ( rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:3080:2: rule__StartFlowElement__Group_4__2__Impl rule__StartFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_12);
+            pushFollow(FOLLOW_13);
             rule__StartFlowElement__Group_4__2__Impl();
 
             state._fsp--;
@@ -9995,21 +9920,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:3108:1: rule__StartFlowElement__Group_4__2__Impl : ( 'inputs' ) ;
+    // InternalTestgeneratorDSL.g:3087:1: rule__StartFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
     public final void rule__StartFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3112:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:3113:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:3091:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:3092:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:3113:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:3114:2: 'inputs'
+            // InternalTestgeneratorDSL.g:3092:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3093:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getStartFlowElementAccess().getInputsKeyword_4_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getInputsKeyword_4_2()); 
+             before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -10032,16 +9957,16 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:3123:1: rule__StartFlowElement__Group_4__3 : rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4 ;
+    // InternalTestgeneratorDSL.g:3102:1: rule__StartFlowElement__Group_4__3 : rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4 ;
     public final void rule__StartFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3127:1: ( rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4 )
-            // InternalTestgeneratorDSL.g:3128:2: rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4
+            // InternalTestgeneratorDSL.g:3106:1: ( rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4 )
+            // InternalTestgeneratorDSL.g:3107:2: rule__StartFlowElement__Group_4__3__Impl rule__StartFlowElement__Group_4__4
             {
-            pushFollow(FOLLOW_13);
+            pushFollow(FOLLOW_20);
             rule__StartFlowElement__Group_4__3__Impl();
 
             state._fsp--;
@@ -10070,21 +9995,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:3135:1: rule__StartFlowElement__Group_4__3__Impl : ( RULE_ASSOCIATION ) ;
+    // InternalTestgeneratorDSL.g:3114:1: rule__StartFlowElement__Group_4__3__Impl : ( RULE_LIST_OPEN ) ;
     public final void rule__StartFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3139:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:3140:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3118:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:3119:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:3140:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:3141:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:3119:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:3120:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); 
 
             }
 
@@ -10107,16 +10032,16 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__4"
-    // InternalTestgeneratorDSL.g:3150:1: rule__StartFlowElement__Group_4__4 : rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5 ;
+    // InternalTestgeneratorDSL.g:3129:1: rule__StartFlowElement__Group_4__4 : rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5 ;
     public final void rule__StartFlowElement__Group_4__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3154:1: ( rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5 )
-            // InternalTestgeneratorDSL.g:3155:2: rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5
+            // InternalTestgeneratorDSL.g:3133:1: ( rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5 )
+            // InternalTestgeneratorDSL.g:3134:2: rule__StartFlowElement__Group_4__4__Impl rule__StartFlowElement__Group_4__5
             {
-            pushFollow(FOLLOW_21);
+            pushFollow(FOLLOW_20);
             rule__StartFlowElement__Group_4__4__Impl();
 
             state._fsp--;
@@ -10145,21 +10070,42 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__4__Impl"
-    // InternalTestgeneratorDSL.g:3162:1: rule__StartFlowElement__Group_4__4__Impl : ( RULE_LIST_OPEN ) ;
+    // InternalTestgeneratorDSL.g:3141:1: rule__StartFlowElement__Group_4__4__Impl : ( ( rule__StartFlowElement__Group_4_4__0 )? ) ;
     public final void rule__StartFlowElement__Group_4__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3166:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:3167:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:3145:1: ( ( ( rule__StartFlowElement__Group_4_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:3146:1: ( ( rule__StartFlowElement__Group_4_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:3167:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:3168:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:3146:1: ( ( rule__StartFlowElement__Group_4_4__0 )? )
+            // InternalTestgeneratorDSL.g:3147:2: ( rule__StartFlowElement__Group_4_4__0 )?
             {
-             before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
+             before(grammarAccess.getStartFlowElementAccess().getGroup_4_4()); 
+            // InternalTestgeneratorDSL.g:3148:2: ( rule__StartFlowElement__Group_4_4__0 )?
+            int alt24=2;
+            int LA24_0 = input.LA(1);
+
+            if ( (LA24_0==RULE_ID) ) {
+                alt24=1;
+            }
+            switch (alt24) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:3148:3: rule__StartFlowElement__Group_4_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__StartFlowElement__Group_4_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getStartFlowElementAccess().getGroup_4_4()); 
 
             }
 
@@ -10182,22 +10128,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__5"
-    // InternalTestgeneratorDSL.g:3177:1: rule__StartFlowElement__Group_4__5 : rule__StartFlowElement__Group_4__5__Impl rule__StartFlowElement__Group_4__6 ;
+    // InternalTestgeneratorDSL.g:3156:1: rule__StartFlowElement__Group_4__5 : rule__StartFlowElement__Group_4__5__Impl ;
     public final void rule__StartFlowElement__Group_4__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3181:1: ( rule__StartFlowElement__Group_4__5__Impl rule__StartFlowElement__Group_4__6 )
-            // InternalTestgeneratorDSL.g:3182:2: rule__StartFlowElement__Group_4__5__Impl rule__StartFlowElement__Group_4__6
+            // InternalTestgeneratorDSL.g:3160:1: ( rule__StartFlowElement__Group_4__5__Impl )
+            // InternalTestgeneratorDSL.g:3161:2: rule__StartFlowElement__Group_4__5__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__StartFlowElement__Group_4__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4__6();
+            rule__StartFlowElement__Group_4__5__Impl();
 
             state._fsp--;
 
@@ -10220,42 +10161,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StartFlowElement__Group_4__5__Impl"
-    // InternalTestgeneratorDSL.g:3189:1: rule__StartFlowElement__Group_4__5__Impl : ( ( rule__StartFlowElement__Group_4_5__0 )? ) ;
+    // InternalTestgeneratorDSL.g:3167:1: rule__StartFlowElement__Group_4__5__Impl : ( RULE_LIST_CLOSED ) ;
     public final void rule__StartFlowElement__Group_4__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3193:1: ( ( ( rule__StartFlowElement__Group_4_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:3194:1: ( ( rule__StartFlowElement__Group_4_5__0 )? )
+            // InternalTestgeneratorDSL.g:3171:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:3172:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:3194:1: ( ( rule__StartFlowElement__Group_4_5__0 )? )
-            // InternalTestgeneratorDSL.g:3195:2: ( rule__StartFlowElement__Group_4_5__0 )?
+            // InternalTestgeneratorDSL.g:3172:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3173:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getStartFlowElementAccess().getGroup_4_5()); 
-            // InternalTestgeneratorDSL.g:3196:2: ( rule__StartFlowElement__Group_4_5__0 )?
-            int alt25=2;
-            int LA25_0 = input.LA(1);
-
-            if ( (LA25_0==RULE_ID) ) {
-                alt25=1;
-            }
-            switch (alt25) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3196:3: rule__StartFlowElement__Group_4_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__StartFlowElement__Group_4_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getStartFlowElementAccess().getGroup_4_5()); 
+             before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); 
 
             }
 
@@ -10277,18 +10197,23 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
     // $ANTLR end "rule__StartFlowElement__Group_4__5__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4__6"
-    // InternalTestgeneratorDSL.g:3204:1: rule__StartFlowElement__Group_4__6 : rule__StartFlowElement__Group_4__6__Impl ;
-    public final void rule__StartFlowElement__Group_4__6() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4__0"
+    // InternalTestgeneratorDSL.g:3183:1: rule__StartFlowElement__Group_4_4__0 : rule__StartFlowElement__Group_4_4__0__Impl rule__StartFlowElement__Group_4_4__1 ;
+    public final void rule__StartFlowElement__Group_4_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3208:1: ( rule__StartFlowElement__Group_4__6__Impl )
-            // InternalTestgeneratorDSL.g:3209:2: rule__StartFlowElement__Group_4__6__Impl
+            // InternalTestgeneratorDSL.g:3187:1: ( rule__StartFlowElement__Group_4_4__0__Impl rule__StartFlowElement__Group_4_4__1 )
+            // InternalTestgeneratorDSL.g:3188:2: rule__StartFlowElement__Group_4_4__0__Impl rule__StartFlowElement__Group_4_4__1
             {
+            pushFollow(FOLLOW_15);
+            rule__StartFlowElement__Group_4_4__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4__6__Impl();
+            rule__StartFlowElement__Group_4_4__1();
 
             state._fsp--;
 
@@ -10307,25 +10232,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4__6"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4__0"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4__6__Impl"
-    // InternalTestgeneratorDSL.g:3215:1: rule__StartFlowElement__Group_4__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__StartFlowElement__Group_4__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4__0__Impl"
+    // InternalTestgeneratorDSL.g:3195:1: rule__StartFlowElement__Group_4_4__0__Impl : ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 ) ) ;
+    public final void rule__StartFlowElement__Group_4_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3219:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:3220:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3199:1: ( ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:3200:1: ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:3220:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:3221:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:3200:1: ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 ) )
+            // InternalTestgeneratorDSL.g:3201:2: ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 )
             {
-             before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
+             before(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_0()); 
+            // InternalTestgeneratorDSL.g:3202:2: ( rule__StartFlowElement__InputVariablesAssignment_4_4_0 )
+            // InternalTestgeneratorDSL.g:3202:3: rule__StartFlowElement__InputVariablesAssignment_4_4_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__StartFlowElement__InputVariablesAssignment_4_4_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_0()); 
 
             }
 
@@ -10344,26 +10279,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4__6__Impl"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4__0__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5__0"
-    // InternalTestgeneratorDSL.g:3231:1: rule__StartFlowElement__Group_4_5__0 : rule__StartFlowElement__Group_4_5__0__Impl rule__StartFlowElement__Group_4_5__1 ;
-    public final void rule__StartFlowElement__Group_4_5__0() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4__1"
+    // InternalTestgeneratorDSL.g:3210:1: rule__StartFlowElement__Group_4_4__1 : rule__StartFlowElement__Group_4_4__1__Impl ;
+    public final void rule__StartFlowElement__Group_4_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3235:1: ( rule__StartFlowElement__Group_4_5__0__Impl rule__StartFlowElement__Group_4_5__1 )
-            // InternalTestgeneratorDSL.g:3236:2: rule__StartFlowElement__Group_4_5__0__Impl rule__StartFlowElement__Group_4_5__1
+            // InternalTestgeneratorDSL.g:3214:1: ( rule__StartFlowElement__Group_4_4__1__Impl )
+            // InternalTestgeneratorDSL.g:3215:2: rule__StartFlowElement__Group_4_4__1__Impl
             {
-            pushFollow(FOLLOW_15);
-            rule__StartFlowElement__Group_4_5__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4_5__1();
+            rule__StartFlowElement__Group_4_4__1__Impl();
 
             state._fsp--;
 
@@ -10382,35 +10312,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5__0"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4__1"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5__0__Impl"
-    // InternalTestgeneratorDSL.g:3243:1: rule__StartFlowElement__Group_4_5__0__Impl : ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 ) ) ;
-    public final void rule__StartFlowElement__Group_4_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4__1__Impl"
+    // InternalTestgeneratorDSL.g:3221:1: rule__StartFlowElement__Group_4_4__1__Impl : ( ( rule__StartFlowElement__Group_4_4_1__0 )* ) ;
+    public final void rule__StartFlowElement__Group_4_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3247:1: ( ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:3248:1: ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:3248:1: ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            // InternalTestgeneratorDSL.g:3249:2: ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 )
+            // InternalTestgeneratorDSL.g:3225:1: ( ( ( rule__StartFlowElement__Group_4_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:3226:1: ( ( rule__StartFlowElement__Group_4_4_1__0 )* )
             {
-             before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
-            // InternalTestgeneratorDSL.g:3250:2: ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 )
-            // InternalTestgeneratorDSL.g:3250:3: rule__StartFlowElement__HardcodedInputsAssignment_4_5_0
+            // InternalTestgeneratorDSL.g:3226:1: ( ( rule__StartFlowElement__Group_4_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:3227:2: ( rule__StartFlowElement__Group_4_4_1__0 )*
             {
-            pushFollow(FOLLOW_2);
-            rule__StartFlowElement__HardcodedInputsAssignment_4_5_0();
+             before(grammarAccess.getStartFlowElementAccess().getGroup_4_4_1()); 
+            // InternalTestgeneratorDSL.g:3228:2: ( rule__StartFlowElement__Group_4_4_1__0 )*
+            loop25:
+            do {
+                int alt25=2;
+                int LA25_0 = input.LA(1);
 
-            state._fsp--;
+                if ( (LA25_0==RULE_SEPARATOR) ) {
+                    alt25=1;
+                }
 
 
-            }
+                switch (alt25) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:3228:3: rule__StartFlowElement__Group_4_4_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__StartFlowElement__Group_4_4_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
 
-             after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
+            	default :
+            	    break loop25;
+                }
+            } while (true);
+
+             after(grammarAccess.getStartFlowElementAccess().getGroup_4_4_1()); 
 
             }
 
@@ -10429,21 +10377,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5__0__Impl"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4__1__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5__1"
-    // InternalTestgeneratorDSL.g:3258:1: rule__StartFlowElement__Group_4_5__1 : rule__StartFlowElement__Group_4_5__1__Impl ;
-    public final void rule__StartFlowElement__Group_4_5__1() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4_1__0"
+    // InternalTestgeneratorDSL.g:3237:1: rule__StartFlowElement__Group_4_4_1__0 : rule__StartFlowElement__Group_4_4_1__0__Impl rule__StartFlowElement__Group_4_4_1__1 ;
+    public final void rule__StartFlowElement__Group_4_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3262:1: ( rule__StartFlowElement__Group_4_5__1__Impl )
-            // InternalTestgeneratorDSL.g:3263:2: rule__StartFlowElement__Group_4_5__1__Impl
+            // InternalTestgeneratorDSL.g:3241:1: ( rule__StartFlowElement__Group_4_4_1__0__Impl rule__StartFlowElement__Group_4_4_1__1 )
+            // InternalTestgeneratorDSL.g:3242:2: rule__StartFlowElement__Group_4_4_1__0__Impl rule__StartFlowElement__Group_4_4_1__1
             {
+            pushFollow(FOLLOW_4);
+            rule__StartFlowElement__Group_4_4_1__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4_5__1__Impl();
+            rule__StartFlowElement__Group_4_4_1__1();
 
             state._fsp--;
 
@@ -10462,53 +10415,105 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5__1"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4_1__0"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5__1__Impl"
-    // InternalTestgeneratorDSL.g:3269:1: rule__StartFlowElement__Group_4_5__1__Impl : ( ( rule__StartFlowElement__Group_4_5_1__0 )* ) ;
-    public final void rule__StartFlowElement__Group_4_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__Group_4_4_1__0__Impl"
+    // InternalTestgeneratorDSL.g:3249:1: rule__StartFlowElement__Group_4_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__StartFlowElement__Group_4_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3273:1: ( ( ( rule__StartFlowElement__Group_4_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:3274:1: ( ( rule__StartFlowElement__Group_4_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:3253:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:3254:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:3274:1: ( ( rule__StartFlowElement__Group_4_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:3275:2: ( rule__StartFlowElement__Group_4_5_1__0 )*
+            // InternalTestgeneratorDSL.g:3254:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:3255:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getStartFlowElementAccess().getGroup_4_5_1()); 
-            // InternalTestgeneratorDSL.g:3276:2: ( rule__StartFlowElement__Group_4_5_1__0 )*
-            loop26:
-            do {
-                int alt26=2;
-                int LA26_0 = input.LA(1);
+             before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); 
 
-                if ( (LA26_0==RULE_SEPARATOR) ) {
-                    alt26=1;
-                }
+            }
 
 
-                switch (alt26) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:3276:3: rule__StartFlowElement__Group_4_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__StartFlowElement__Group_4_5_1__0();
+            }
 
-            	    state._fsp--;
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
 
+        }
+        return ;
+    }
+    // $ANTLR end "rule__StartFlowElement__Group_4_4_1__0__Impl"
 
-            	    }
-            	    break;
 
-            	default :
-            	    break loop26;
-                }
-            } while (true);
+    // $ANTLR start "rule__StartFlowElement__Group_4_4_1__1"
+    // InternalTestgeneratorDSL.g:3264:1: rule__StartFlowElement__Group_4_4_1__1 : rule__StartFlowElement__Group_4_4_1__1__Impl ;
+    public final void rule__StartFlowElement__Group_4_4_1__1() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:3268:1: ( rule__StartFlowElement__Group_4_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:3269:2: rule__StartFlowElement__Group_4_4_1__1__Impl
+            {
+            pushFollow(FOLLOW_2);
+            rule__StartFlowElement__Group_4_4_1__1__Impl();
+
+            state._fsp--;
+
+
+            }
+
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__StartFlowElement__Group_4_4_1__1"
+
+
+    // $ANTLR start "rule__StartFlowElement__Group_4_4_1__1__Impl"
+    // InternalTestgeneratorDSL.g:3275:1: rule__StartFlowElement__Group_4_4_1__1__Impl : ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 ) ) ;
+    public final void rule__StartFlowElement__Group_4_4_1__1__Impl() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:3279:1: ( ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:3280:1: ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 ) )
+            {
+            // InternalTestgeneratorDSL.g:3280:1: ( ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:3281:2: ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 )
+            {
+             before(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); 
+            // InternalTestgeneratorDSL.g:3282:2: ( rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 )
+            // InternalTestgeneratorDSL.g:3282:3: rule__StartFlowElement__InputVariablesAssignment_4_4_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__StartFlowElement__InputVariablesAssignment_4_4_1_1();
+
+            state._fsp--;
+
+
+            }
 
-             after(grammarAccess.getStartFlowElementAccess().getGroup_4_5_1()); 
+             after(grammarAccess.getStartFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); 
 
             }
 
@@ -10527,26 +10532,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5__1__Impl"
+    // $ANTLR end "rule__StartFlowElement__Group_4_4_1__1__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5_1__0"
-    // InternalTestgeneratorDSL.g:3285:1: rule__StartFlowElement__Group_4_5_1__0 : rule__StartFlowElement__Group_4_5_1__0__Impl rule__StartFlowElement__Group_4_5_1__1 ;
-    public final void rule__StartFlowElement__Group_4_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:3291:1: rule__EndFlowElement__Group__0 : rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1 ;
+    public final void rule__EndFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3289:1: ( rule__StartFlowElement__Group_4_5_1__0__Impl rule__StartFlowElement__Group_4_5_1__1 )
-            // InternalTestgeneratorDSL.g:3290:2: rule__StartFlowElement__Group_4_5_1__0__Impl rule__StartFlowElement__Group_4_5_1__1
+            // InternalTestgeneratorDSL.g:3295:1: ( rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:3296:2: rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1
             {
             pushFollow(FOLLOW_4);
-            rule__StartFlowElement__Group_4_5_1__0__Impl();
+            rule__EndFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4_5_1__1();
+            rule__EndFlowElement__Group__1();
 
             state._fsp--;
 
@@ -10565,25 +10570,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5_1__0"
+    // $ANTLR end "rule__EndFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:3297:1: rule__StartFlowElement__Group_4_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__StartFlowElement__Group_4_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:3303:1: rule__EndFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__EndFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3301:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:3302:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:3307:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:3308:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:3302:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:3303:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:3308:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:3309:2: 'FlowElement'
             {
-             before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
+             before(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -10602,21 +10607,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5_1__0__Impl"
+    // $ANTLR end "rule__EndFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5_1__1"
-    // InternalTestgeneratorDSL.g:3312:1: rule__StartFlowElement__Group_4_5_1__1 : rule__StartFlowElement__Group_4_5_1__1__Impl ;
-    public final void rule__StartFlowElement__Group_4_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:3318:1: rule__EndFlowElement__Group__1 : rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2 ;
+    public final void rule__EndFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3316:1: ( rule__StartFlowElement__Group_4_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:3317:2: rule__StartFlowElement__Group_4_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:3322:1: ( rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:3323:2: rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2
             {
+            pushFollow(FOLLOW_12);
+            rule__EndFlowElement__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_4_5_1__1__Impl();
+            rule__EndFlowElement__Group__2();
 
             state._fsp--;
 
@@ -10635,35 +10645,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5_1__1"
+    // $ANTLR end "rule__EndFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_4_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:3323:1: rule__StartFlowElement__Group_4_5_1__1__Impl : ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) ;
-    public final void rule__StartFlowElement__Group_4_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:3330:1: rule__EndFlowElement__Group__1__Impl : ( ( rule__EndFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__EndFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3327:1: ( ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:3328:1: ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:3334:1: ( ( ( rule__EndFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:3335:1: ( ( rule__EndFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:3328:1: ( ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:3329:2: ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 )
+            // InternalTestgeneratorDSL.g:3335:1: ( ( rule__EndFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:3336:2: ( rule__EndFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
-            // InternalTestgeneratorDSL.g:3330:2: ( rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 )
-            // InternalTestgeneratorDSL.g:3330:3: rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1
+             before(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:3337:2: ( rule__EndFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:3337:3: rule__EndFlowElement__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1();
+            rule__EndFlowElement__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
+             after(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -10682,26 +10692,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_4_5_1__1__Impl"
+    // $ANTLR end "rule__EndFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__0"
-    // InternalTestgeneratorDSL.g:3339:1: rule__StartFlowElement__Group_5__0 : rule__StartFlowElement__Group_5__0__Impl rule__StartFlowElement__Group_5__1 ;
-    public final void rule__StartFlowElement__Group_5__0() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:3345:1: rule__EndFlowElement__Group__2 : rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3 ;
+    public final void rule__EndFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3343:1: ( rule__StartFlowElement__Group_5__0__Impl rule__StartFlowElement__Group_5__1 )
-            // InternalTestgeneratorDSL.g:3344:2: rule__StartFlowElement__Group_5__0__Impl rule__StartFlowElement__Group_5__1
+            // InternalTestgeneratorDSL.g:3349:1: ( rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:3350:2: rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3
             {
-            pushFollow(FOLLOW_22);
-            rule__StartFlowElement__Group_5__0__Impl();
+            pushFollow(FOLLOW_21);
+            rule__EndFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__1();
+            rule__EndFlowElement__Group__3();
 
             state._fsp--;
 
@@ -10720,25 +10730,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__0"
+    // $ANTLR end "rule__EndFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:3351:1: rule__StartFlowElement__Group_5__0__Impl : ( 'with' ) ;
-    public final void rule__StartFlowElement__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:3357:1: rule__EndFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__EndFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3355:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:3356:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:3361:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:3362:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:3356:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:3357:2: 'with'
+            // InternalTestgeneratorDSL.g:3362:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3363:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getStartFlowElementAccess().getWithKeyword_5_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getWithKeyword_5_0()); 
+             before(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -10757,26 +10767,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__0__Impl"
+    // $ANTLR end "rule__EndFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__1"
-    // InternalTestgeneratorDSL.g:3366:1: rule__StartFlowElement__Group_5__1 : rule__StartFlowElement__Group_5__1__Impl rule__StartFlowElement__Group_5__2 ;
-    public final void rule__StartFlowElement__Group_5__1() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:3372:1: rule__EndFlowElement__Group__3 : rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4 ;
+    public final void rule__EndFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3370:1: ( rule__StartFlowElement__Group_5__1__Impl rule__StartFlowElement__Group_5__2 )
-            // InternalTestgeneratorDSL.g:3371:2: rule__StartFlowElement__Group_5__1__Impl rule__StartFlowElement__Group_5__2
+            // InternalTestgeneratorDSL.g:3376:1: ( rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:3377:2: rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4
             {
-            pushFollow(FOLLOW_12);
-            rule__StartFlowElement__Group_5__1__Impl();
+            pushFollow(FOLLOW_22);
+            rule__EndFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__2();
+            rule__EndFlowElement__Group__4();
 
             state._fsp--;
 
@@ -10795,25 +10805,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__1"
+    // $ANTLR end "rule__EndFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:3378:1: rule__StartFlowElement__Group_5__1__Impl : ( 'startVariables' ) ;
-    public final void rule__StartFlowElement__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:3384:1: rule__EndFlowElement__Group__3__Impl : ( 'EndEvent' ) ;
+    public final void rule__EndFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3382:1: ( ( 'startVariables' ) )
-            // InternalTestgeneratorDSL.g:3383:1: ( 'startVariables' )
+            // InternalTestgeneratorDSL.g:3388:1: ( ( 'EndEvent' ) )
+            // InternalTestgeneratorDSL.g:3389:1: ( 'EndEvent' )
             {
-            // InternalTestgeneratorDSL.g:3383:1: ( 'startVariables' )
-            // InternalTestgeneratorDSL.g:3384:2: 'startVariables'
+            // InternalTestgeneratorDSL.g:3389:1: ( 'EndEvent' )
+            // InternalTestgeneratorDSL.g:3390:2: 'EndEvent'
             {
-             before(grammarAccess.getStartFlowElementAccess().getStartVariablesKeyword_5_1()); 
+             before(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); 
             match(input,38,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getStartVariablesKeyword_5_1()); 
+             after(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); 
 
             }
 
@@ -10832,26 +10842,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__1__Impl"
+    // $ANTLR end "rule__EndFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__2"
-    // InternalTestgeneratorDSL.g:3393:1: rule__StartFlowElement__Group_5__2 : rule__StartFlowElement__Group_5__2__Impl rule__StartFlowElement__Group_5__3 ;
-    public final void rule__StartFlowElement__Group_5__2() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:3399:1: rule__EndFlowElement__Group__4 : rule__EndFlowElement__Group__4__Impl ;
+    public final void rule__EndFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3397:1: ( rule__StartFlowElement__Group_5__2__Impl rule__StartFlowElement__Group_5__3 )
-            // InternalTestgeneratorDSL.g:3398:2: rule__StartFlowElement__Group_5__2__Impl rule__StartFlowElement__Group_5__3
+            // InternalTestgeneratorDSL.g:3403:1: ( rule__EndFlowElement__Group__4__Impl )
+            // InternalTestgeneratorDSL.g:3404:2: rule__EndFlowElement__Group__4__Impl
             {
-            pushFollow(FOLLOW_13);
-            rule__StartFlowElement__Group_5__2__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__3();
+            rule__EndFlowElement__Group__4__Impl();
 
             state._fsp--;
 
@@ -10870,25 +10875,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__2"
+    // $ANTLR end "rule__EndFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__2__Impl"
-    // InternalTestgeneratorDSL.g:3405:1: rule__StartFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__StartFlowElement__Group_5__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:3410:1: rule__EndFlowElement__Group__4__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__EndFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3409:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:3410:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3414:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:3415:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3410:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:3411:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:3415:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3416:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             before(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
 
             }
 
@@ -10907,26 +10912,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__2__Impl"
+    // $ANTLR end "rule__EndFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__3"
-    // InternalTestgeneratorDSL.g:3420:1: rule__StartFlowElement__Group_5__3 : rule__StartFlowElement__Group_5__3__Impl rule__StartFlowElement__Group_5__4 ;
-    public final void rule__StartFlowElement__Group_5__3() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:3426:1: rule__UserTaskFlowElement__Group__0 : rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1 ;
+    public final void rule__UserTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3424:1: ( rule__StartFlowElement__Group_5__3__Impl rule__StartFlowElement__Group_5__4 )
-            // InternalTestgeneratorDSL.g:3425:2: rule__StartFlowElement__Group_5__3__Impl rule__StartFlowElement__Group_5__4
+            // InternalTestgeneratorDSL.g:3430:1: ( rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:3431:2: rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1
             {
-            pushFollow(FOLLOW_21);
-            rule__StartFlowElement__Group_5__3__Impl();
+            pushFollow(FOLLOW_4);
+            rule__UserTaskFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__4();
+            rule__UserTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -10945,25 +10950,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__3"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__3__Impl"
-    // InternalTestgeneratorDSL.g:3432:1: rule__StartFlowElement__Group_5__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__StartFlowElement__Group_5__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:3438:1: rule__UserTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__UserTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3436:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:3437:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:3442:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:3443:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:3437:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:3438:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:3443:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:3444:2: 'FlowElement'
             {
-             before(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -10982,26 +10987,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__3__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__4"
-    // InternalTestgeneratorDSL.g:3447:1: rule__StartFlowElement__Group_5__4 : rule__StartFlowElement__Group_5__4__Impl rule__StartFlowElement__Group_5__5 ;
-    public final void rule__StartFlowElement__Group_5__4() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:3453:1: rule__UserTaskFlowElement__Group__1 : rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2 ;
+    public final void rule__UserTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3451:1: ( rule__StartFlowElement__Group_5__4__Impl rule__StartFlowElement__Group_5__5 )
-            // InternalTestgeneratorDSL.g:3452:2: rule__StartFlowElement__Group_5__4__Impl rule__StartFlowElement__Group_5__5
+            // InternalTestgeneratorDSL.g:3457:1: ( rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:3458:2: rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2
             {
-            pushFollow(FOLLOW_21);
-            rule__StartFlowElement__Group_5__4__Impl();
+            pushFollow(FOLLOW_12);
+            rule__UserTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__5();
+            rule__UserTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -11020,46 +11025,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__4"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__4__Impl"
-    // InternalTestgeneratorDSL.g:3459:1: rule__StartFlowElement__Group_5__4__Impl : ( ( rule__StartFlowElement__Group_5_4__0 )? ) ;
-    public final void rule__StartFlowElement__Group_5__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:3465:1: rule__UserTaskFlowElement__Group__1__Impl : ( ( rule__UserTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__UserTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3463:1: ( ( ( rule__StartFlowElement__Group_5_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:3464:1: ( ( rule__StartFlowElement__Group_5_4__0 )? )
+            // InternalTestgeneratorDSL.g:3469:1: ( ( ( rule__UserTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:3470:1: ( ( rule__UserTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:3464:1: ( ( rule__StartFlowElement__Group_5_4__0 )? )
-            // InternalTestgeneratorDSL.g:3465:2: ( rule__StartFlowElement__Group_5_4__0 )?
+            // InternalTestgeneratorDSL.g:3470:1: ( ( rule__UserTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:3471:2: ( rule__UserTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getStartFlowElementAccess().getGroup_5_4()); 
-            // InternalTestgeneratorDSL.g:3466:2: ( rule__StartFlowElement__Group_5_4__0 )?
-            int alt27=2;
-            int LA27_0 = input.LA(1);
-
-            if ( (LA27_0==RULE_ID) ) {
-                alt27=1;
-            }
-            switch (alt27) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3466:3: rule__StartFlowElement__Group_5_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__StartFlowElement__Group_5_4__0();
-
-                    state._fsp--;
+             before(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:3472:2: ( rule__UserTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:3472:3: rule__UserTaskFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__UserTaskFlowElement__NameAssignment_1();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getStartFlowElementAccess().getGroup_5_4()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -11078,21 +11072,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__4__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__5"
-    // InternalTestgeneratorDSL.g:3474:1: rule__StartFlowElement__Group_5__5 : rule__StartFlowElement__Group_5__5__Impl ;
-    public final void rule__StartFlowElement__Group_5__5() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:3480:1: rule__UserTaskFlowElement__Group__2 : rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3 ;
+    public final void rule__UserTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3478:1: ( rule__StartFlowElement__Group_5__5__Impl )
-            // InternalTestgeneratorDSL.g:3479:2: rule__StartFlowElement__Group_5__5__Impl
+            // InternalTestgeneratorDSL.g:3484:1: ( rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:3485:2: rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3
             {
+            pushFollow(FOLLOW_23);
+            rule__UserTaskFlowElement__Group__2__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5__5__Impl();
+            rule__UserTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -11111,25 +11110,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__5"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5__5__Impl"
-    // InternalTestgeneratorDSL.g:3485:1: rule__StartFlowElement__Group_5__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__StartFlowElement__Group_5__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:3492:1: rule__UserTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__UserTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3489:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:3490:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3496:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:3497:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:3490:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:3491:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:3497:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3498:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -11148,26 +11147,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5__5__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4__0"
-    // InternalTestgeneratorDSL.g:3501:1: rule__StartFlowElement__Group_5_4__0 : rule__StartFlowElement__Group_5_4__0__Impl rule__StartFlowElement__Group_5_4__1 ;
-    public final void rule__StartFlowElement__Group_5_4__0() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:3507:1: rule__UserTaskFlowElement__Group__3 : rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4 ;
+    public final void rule__UserTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3505:1: ( rule__StartFlowElement__Group_5_4__0__Impl rule__StartFlowElement__Group_5_4__1 )
-            // InternalTestgeneratorDSL.g:3506:2: rule__StartFlowElement__Group_5_4__0__Impl rule__StartFlowElement__Group_5_4__1
+            // InternalTestgeneratorDSL.g:3511:1: ( rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:3512:2: rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_15);
-            rule__StartFlowElement__Group_5_4__0__Impl();
+            pushFollow(FOLLOW_24);
+            rule__UserTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5_4__1();
+            rule__UserTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -11186,35 +11185,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4__0"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4__0__Impl"
-    // InternalTestgeneratorDSL.g:3513:1: rule__StartFlowElement__Group_5_4__0__Impl : ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 ) ) ;
-    public final void rule__StartFlowElement__Group_5_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:3519:1: rule__UserTaskFlowElement__Group__3__Impl : ( 'UserTask' ) ;
+    public final void rule__UserTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3517:1: ( ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:3518:1: ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 ) )
+            // InternalTestgeneratorDSL.g:3523:1: ( ( 'UserTask' ) )
+            // InternalTestgeneratorDSL.g:3524:1: ( 'UserTask' )
             {
-            // InternalTestgeneratorDSL.g:3518:1: ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 ) )
-            // InternalTestgeneratorDSL.g:3519:2: ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 )
+            // InternalTestgeneratorDSL.g:3524:1: ( 'UserTask' )
+            // InternalTestgeneratorDSL.g:3525:2: 'UserTask'
             {
-             before(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_0()); 
-            // InternalTestgeneratorDSL.g:3520:2: ( rule__StartFlowElement__StartVariablesAssignment_5_4_0 )
-            // InternalTestgeneratorDSL.g:3520:3: rule__StartFlowElement__StartVariablesAssignment_5_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__StartFlowElement__StartVariablesAssignment_5_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); 
+            match(input,39,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); 
 
             }
 
@@ -11233,21 +11222,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4__0__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4__1"
-    // InternalTestgeneratorDSL.g:3528:1: rule__StartFlowElement__Group_5_4__1 : rule__StartFlowElement__Group_5_4__1__Impl ;
-    public final void rule__StartFlowElement__Group_5_4__1() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:3534:1: rule__UserTaskFlowElement__Group__4 : rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5 ;
+    public final void rule__UserTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3532:1: ( rule__StartFlowElement__Group_5_4__1__Impl )
-            // InternalTestgeneratorDSL.g:3533:2: rule__StartFlowElement__Group_5_4__1__Impl
+            // InternalTestgeneratorDSL.g:3538:1: ( rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:3539:2: rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5
             {
+            pushFollow(FOLLOW_24);
+            rule__UserTaskFlowElement__Group__4__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5_4__1__Impl();
+            rule__UserTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -11266,53 +11260,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4__1"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4__1__Impl"
-    // InternalTestgeneratorDSL.g:3539:1: rule__StartFlowElement__Group_5_4__1__Impl : ( ( rule__StartFlowElement__Group_5_4_1__0 )* ) ;
-    public final void rule__StartFlowElement__Group_5_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:3546:1: rule__UserTaskFlowElement__Group__4__Impl : ( ( rule__UserTaskFlowElement__Group_4__0 )? ) ;
+    public final void rule__UserTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3543:1: ( ( ( rule__StartFlowElement__Group_5_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:3544:1: ( ( rule__StartFlowElement__Group_5_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:3550:1: ( ( ( rule__UserTaskFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:3551:1: ( ( rule__UserTaskFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:3544:1: ( ( rule__StartFlowElement__Group_5_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:3545:2: ( rule__StartFlowElement__Group_5_4_1__0 )*
+            // InternalTestgeneratorDSL.g:3551:1: ( ( rule__UserTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:3552:2: ( rule__UserTaskFlowElement__Group_4__0 )?
             {
-             before(grammarAccess.getStartFlowElementAccess().getGroup_5_4_1()); 
-            // InternalTestgeneratorDSL.g:3546:2: ( rule__StartFlowElement__Group_5_4_1__0 )*
-            loop28:
-            do {
-                int alt28=2;
-                int LA28_0 = input.LA(1);
-
-                if ( (LA28_0==RULE_SEPARATOR) ) {
-                    alt28=1;
-                }
-
+             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:3553:2: ( rule__UserTaskFlowElement__Group_4__0 )?
+            int alt26=2;
+            int LA26_0 = input.LA(1);
 
-                switch (alt28) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:3546:3: rule__StartFlowElement__Group_5_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__StartFlowElement__Group_5_4_1__0();
+            if ( (LA26_0==29) ) {
+                alt26=1;
+            }
+            switch (alt26) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:3553:3: rule__UserTaskFlowElement__Group_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__UserTaskFlowElement__Group_4__0();
 
-            	    state._fsp--;
+                    state._fsp--;
 
 
-            	    }
-            	    break;
+                    }
+                    break;
 
-            	default :
-            	    break loop28;
-                }
-            } while (true);
+            }
 
-             after(grammarAccess.getStartFlowElementAccess().getGroup_5_4_1()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); 
 
             }
 
@@ -11331,26 +11318,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4__1__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4_1__0"
-    // InternalTestgeneratorDSL.g:3555:1: rule__StartFlowElement__Group_5_4_1__0 : rule__StartFlowElement__Group_5_4_1__0__Impl rule__StartFlowElement__Group_5_4_1__1 ;
-    public final void rule__StartFlowElement__Group_5_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:3561:1: rule__UserTaskFlowElement__Group__5 : rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6 ;
+    public final void rule__UserTaskFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3559:1: ( rule__StartFlowElement__Group_5_4_1__0__Impl rule__StartFlowElement__Group_5_4_1__1 )
-            // InternalTestgeneratorDSL.g:3560:2: rule__StartFlowElement__Group_5_4_1__0__Impl rule__StartFlowElement__Group_5_4_1__1
+            // InternalTestgeneratorDSL.g:3565:1: ( rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6 )
+            // InternalTestgeneratorDSL.g:3566:2: rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6
             {
-            pushFollow(FOLLOW_4);
-            rule__StartFlowElement__Group_5_4_1__0__Impl();
+            pushFollow(FOLLOW_24);
+            rule__UserTaskFlowElement__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5_4_1__1();
+            rule__UserTaskFlowElement__Group__6();
 
             state._fsp--;
 
@@ -11369,25 +11356,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4_1__0"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:3567:1: rule__StartFlowElement__Group_5_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__StartFlowElement__Group_5_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:3573:1: rule__UserTaskFlowElement__Group__5__Impl : ( ( rule__UserTaskFlowElement__Group_5__0 )? ) ;
+    public final void rule__UserTaskFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3571:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:3572:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:3577:1: ( ( ( rule__UserTaskFlowElement__Group_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:3578:1: ( ( rule__UserTaskFlowElement__Group_5__0 )? )
             {
-            // InternalTestgeneratorDSL.g:3572:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:3573:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:3578:1: ( ( rule__UserTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:3579:2: ( rule__UserTaskFlowElement__Group_5__0 )?
             {
-             before(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); 
+            // InternalTestgeneratorDSL.g:3580:2: ( rule__UserTaskFlowElement__Group_5__0 )?
+            int alt27=2;
+            int LA27_0 = input.LA(1);
+
+            if ( (LA27_0==40) ) {
+                alt27=1;
+            }
+            switch (alt27) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:3580:3: rule__UserTaskFlowElement__Group_5__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__UserTaskFlowElement__Group_5__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); 
 
             }
 
@@ -11406,21 +11414,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4_1__0__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4_1__1"
-    // InternalTestgeneratorDSL.g:3582:1: rule__StartFlowElement__Group_5_4_1__1 : rule__StartFlowElement__Group_5_4_1__1__Impl ;
-    public final void rule__StartFlowElement__Group_5_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__6"
+    // InternalTestgeneratorDSL.g:3588:1: rule__UserTaskFlowElement__Group__6 : rule__UserTaskFlowElement__Group__6__Impl ;
+    public final void rule__UserTaskFlowElement__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3586:1: ( rule__StartFlowElement__Group_5_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:3587:2: rule__StartFlowElement__Group_5_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:3592:1: ( rule__UserTaskFlowElement__Group__6__Impl )
+            // InternalTestgeneratorDSL.g:3593:2: rule__UserTaskFlowElement__Group__6__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__StartFlowElement__Group_5_4_1__1__Impl();
+            rule__UserTaskFlowElement__Group__6__Impl();
 
             state._fsp--;
 
@@ -11439,35 +11447,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4_1__1"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__6"
 
 
-    // $ANTLR start "rule__StartFlowElement__Group_5_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:3593:1: rule__StartFlowElement__Group_5_4_1__1__Impl : ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 ) ) ;
-    public final void rule__StartFlowElement__Group_5_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:3599:1: rule__UserTaskFlowElement__Group__6__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__UserTaskFlowElement__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3597:1: ( ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:3598:1: ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:3603:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:3604:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3598:1: ( ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:3599:2: ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 )
+            // InternalTestgeneratorDSL.g:3604:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3605:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_1_1()); 
-            // InternalTestgeneratorDSL.g:3600:2: ( rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 )
-            // InternalTestgeneratorDSL.g:3600:3: rule__StartFlowElement__StartVariablesAssignment_5_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__StartFlowElement__StartVariablesAssignment_5_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStartFlowElementAccess().getStartVariablesAssignment_5_4_1_1()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
 
             }
 
@@ -11486,26 +11484,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__Group_5_4_1__1__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group__6__Impl"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:3609:1: rule__EndFlowElement__Group__0 : rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1 ;
-    public final void rule__EndFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__0"
+    // InternalTestgeneratorDSL.g:3615:1: rule__UserTaskFlowElement__Group_4__0 : rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1 ;
+    public final void rule__UserTaskFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3613:1: ( rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:3614:2: rule__EndFlowElement__Group__0__Impl rule__EndFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:3619:1: ( rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:3620:2: rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1
             {
-            pushFollow(FOLLOW_4);
-            rule__EndFlowElement__Group__0__Impl();
+            pushFollow(FOLLOW_19);
+            rule__UserTaskFlowElement__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__EndFlowElement__Group__1();
+            rule__UserTaskFlowElement__Group_4__1();
 
             state._fsp--;
 
@@ -11524,25 +11522,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__0"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__0"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:3621:1: rule__EndFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__EndFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:3627:1: rule__UserTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
+    public final void rule__UserTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3625:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:3626:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:3631:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:3632:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:3626:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:3627:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:3632:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:3633:2: 'with'
             {
-             before(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); 
 
             }
 
@@ -11561,26 +11559,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:3636:1: rule__EndFlowElement__Group__1 : rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2 ;
-    public final void rule__EndFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__1"
+    // InternalTestgeneratorDSL.g:3642:1: rule__UserTaskFlowElement__Group_4__1 : rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2 ;
+    public final void rule__UserTaskFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3640:1: ( rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:3641:2: rule__EndFlowElement__Group__1__Impl rule__EndFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:3646:1: ( rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:3647:2: rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2
             {
             pushFollow(FOLLOW_12);
-            rule__EndFlowElement__Group__1__Impl();
+            rule__UserTaskFlowElement__Group_4__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__EndFlowElement__Group__2();
+            rule__UserTaskFlowElement__Group_4__2();
 
             state._fsp--;
 
@@ -11599,35 +11597,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__1"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__1"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:3648:1: rule__EndFlowElement__Group__1__Impl : ( ( rule__EndFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__EndFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:3654:1: rule__UserTaskFlowElement__Group_4__1__Impl : ( 'inputVariables' ) ;
+    public final void rule__UserTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3652:1: ( ( ( rule__EndFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:3653:1: ( ( rule__EndFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:3658:1: ( ( 'inputVariables' ) )
+            // InternalTestgeneratorDSL.g:3659:1: ( 'inputVariables' )
             {
-            // InternalTestgeneratorDSL.g:3653:1: ( ( rule__EndFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:3654:2: ( rule__EndFlowElement__NameAssignment_1 )
-            {
-             before(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:3655:2: ( rule__EndFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:3655:3: rule__EndFlowElement__NameAssignment_1
+            // InternalTestgeneratorDSL.g:3659:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:3660:2: 'inputVariables'
             {
-            pushFollow(FOLLOW_2);
-            rule__EndFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getEndFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_4_1()); 
+            match(input,37,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_4_1()); 
 
             }
 
@@ -11646,26 +11634,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:3663:1: rule__EndFlowElement__Group__2 : rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3 ;
-    public final void rule__EndFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__2"
+    // InternalTestgeneratorDSL.g:3669:1: rule__UserTaskFlowElement__Group_4__2 : rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3 ;
+    public final void rule__UserTaskFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3667:1: ( rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:3668:2: rule__EndFlowElement__Group__2__Impl rule__EndFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:3673:1: ( rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:3674:2: rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_23);
-            rule__EndFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_13);
+            rule__UserTaskFlowElement__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__EndFlowElement__Group__3();
+            rule__UserTaskFlowElement__Group_4__3();
 
             state._fsp--;
 
@@ -11684,25 +11672,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__2"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__2"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:3675:1: rule__EndFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__EndFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:3681:1: rule__UserTaskFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__UserTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3679:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:3680:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3685:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:3686:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:3680:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:3681:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:3686:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3687:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -11721,26 +11709,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:3690:1: rule__EndFlowElement__Group__3 : rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4 ;
-    public final void rule__EndFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__3"
+    // InternalTestgeneratorDSL.g:3696:1: rule__UserTaskFlowElement__Group_4__3 : rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4 ;
+    public final void rule__UserTaskFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3694:1: ( rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:3695:2: rule__EndFlowElement__Group__3__Impl rule__EndFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:3700:1: ( rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4 )
+            // InternalTestgeneratorDSL.g:3701:2: rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4
             {
-            pushFollow(FOLLOW_24);
-            rule__EndFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_20);
+            rule__UserTaskFlowElement__Group_4__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__EndFlowElement__Group__4();
+            rule__UserTaskFlowElement__Group_4__4();
 
             state._fsp--;
 
@@ -11759,25 +11747,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__3"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__3"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:3702:1: rule__EndFlowElement__Group__3__Impl : ( 'EndEvent' ) ;
-    public final void rule__EndFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:3708:1: rule__UserTaskFlowElement__Group_4__3__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__UserTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3706:1: ( ( 'EndEvent' ) )
-            // InternalTestgeneratorDSL.g:3707:1: ( 'EndEvent' )
+            // InternalTestgeneratorDSL.g:3712:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:3713:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:3707:1: ( 'EndEvent' )
-            // InternalTestgeneratorDSL.g:3708:2: 'EndEvent'
+            // InternalTestgeneratorDSL.g:3713:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:3714:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); 
-            match(input,39,FOLLOW_2); 
-             after(grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3()); 
 
             }
 
@@ -11796,21 +11784,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:3717:1: rule__EndFlowElement__Group__4 : rule__EndFlowElement__Group__4__Impl ;
-    public final void rule__EndFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__4"
+    // InternalTestgeneratorDSL.g:3723:1: rule__UserTaskFlowElement__Group_4__4 : rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5 ;
+    public final void rule__UserTaskFlowElement__Group_4__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3721:1: ( rule__EndFlowElement__Group__4__Impl )
-            // InternalTestgeneratorDSL.g:3722:2: rule__EndFlowElement__Group__4__Impl
+            // InternalTestgeneratorDSL.g:3727:1: ( rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5 )
+            // InternalTestgeneratorDSL.g:3728:2: rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5
             {
+            pushFollow(FOLLOW_20);
+            rule__UserTaskFlowElement__Group_4__4__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__EndFlowElement__Group__4__Impl();
+            rule__UserTaskFlowElement__Group_4__5();
 
             state._fsp--;
 
@@ -11829,25 +11822,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__4"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__4"
 
 
-    // $ANTLR start "rule__EndFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:3728:1: rule__EndFlowElement__Group__4__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__EndFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__4__Impl"
+    // InternalTestgeneratorDSL.g:3735:1: rule__UserTaskFlowElement__Group_4__4__Impl : ( ( rule__UserTaskFlowElement__Group_4_4__0 )? ) ;
+    public final void rule__UserTaskFlowElement__Group_4__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3732:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3733:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3739:1: ( ( ( rule__UserTaskFlowElement__Group_4_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:3740:1: ( ( rule__UserTaskFlowElement__Group_4_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:3733:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3734:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:3740:1: ( ( rule__UserTaskFlowElement__Group_4_4__0 )? )
+            // InternalTestgeneratorDSL.g:3741:2: ( rule__UserTaskFlowElement__Group_4_4__0 )?
             {
-             before(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getEndFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4()); 
+            // InternalTestgeneratorDSL.g:3742:2: ( rule__UserTaskFlowElement__Group_4_4__0 )?
+            int alt28=2;
+            int LA28_0 = input.LA(1);
+
+            if ( (LA28_0==RULE_ID) ) {
+                alt28=1;
+            }
+            switch (alt28) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:3742:3: rule__UserTaskFlowElement__Group_4_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__UserTaskFlowElement__Group_4_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4()); 
 
             }
 
@@ -11866,26 +11880,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__4__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:3744:1: rule__UserTaskFlowElement__Group__0 : rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1 ;
-    public final void rule__UserTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__5"
+    // InternalTestgeneratorDSL.g:3750:1: rule__UserTaskFlowElement__Group_4__5 : rule__UserTaskFlowElement__Group_4__5__Impl ;
+    public final void rule__UserTaskFlowElement__Group_4__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3748:1: ( rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:3749:2: rule__UserTaskFlowElement__Group__0__Impl rule__UserTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:3754:1: ( rule__UserTaskFlowElement__Group_4__5__Impl )
+            // InternalTestgeneratorDSL.g:3755:2: rule__UserTaskFlowElement__Group_4__5__Impl
             {
-            pushFollow(FOLLOW_4);
-            rule__UserTaskFlowElement__Group__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__1();
+            rule__UserTaskFlowElement__Group_4__5__Impl();
 
             state._fsp--;
 
@@ -11904,25 +11913,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__0"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__5"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:3756:1: rule__UserTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__UserTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4__5__Impl"
+    // InternalTestgeneratorDSL.g:3761:1: rule__UserTaskFlowElement__Group_4__5__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__UserTaskFlowElement__Group_4__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3760:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:3761:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:3765:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:3766:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:3761:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:3762:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:3766:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3767:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5()); 
 
             }
 
@@ -11941,26 +11950,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4__5__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:3771:1: rule__UserTaskFlowElement__Group__1 : rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2 ;
-    public final void rule__UserTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4__0"
+    // InternalTestgeneratorDSL.g:3777:1: rule__UserTaskFlowElement__Group_4_4__0 : rule__UserTaskFlowElement__Group_4_4__0__Impl rule__UserTaskFlowElement__Group_4_4__1 ;
+    public final void rule__UserTaskFlowElement__Group_4_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3775:1: ( rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:3776:2: rule__UserTaskFlowElement__Group__1__Impl rule__UserTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:3781:1: ( rule__UserTaskFlowElement__Group_4_4__0__Impl rule__UserTaskFlowElement__Group_4_4__1 )
+            // InternalTestgeneratorDSL.g:3782:2: rule__UserTaskFlowElement__Group_4_4__0__Impl rule__UserTaskFlowElement__Group_4_4__1
             {
-            pushFollow(FOLLOW_12);
-            rule__UserTaskFlowElement__Group__1__Impl();
+            pushFollow(FOLLOW_15);
+            rule__UserTaskFlowElement__Group_4_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__2();
+            rule__UserTaskFlowElement__Group_4_4__1();
 
             state._fsp--;
 
@@ -11979,35 +11988,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__1"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:3783:1: rule__UserTaskFlowElement__Group__1__Impl : ( ( rule__UserTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__UserTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4__0__Impl"
+    // InternalTestgeneratorDSL.g:3789:1: rule__UserTaskFlowElement__Group_4_4__0__Impl : ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 ) ) ;
+    public final void rule__UserTaskFlowElement__Group_4_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3787:1: ( ( ( rule__UserTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:3788:1: ( ( rule__UserTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:3793:1: ( ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:3794:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:3788:1: ( ( rule__UserTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:3789:2: ( rule__UserTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:3794:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 ) )
+            // InternalTestgeneratorDSL.g:3795:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:3790:2: ( rule__UserTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:3790:3: rule__UserTaskFlowElement__NameAssignment_1
+             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_0()); 
+            // InternalTestgeneratorDSL.g:3796:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 )
+            // InternalTestgeneratorDSL.g:3796:3: rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__NameAssignment_1();
+            rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getNameAssignment_1()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_0()); 
 
             }
 
@@ -12026,26 +12035,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:3798:1: rule__UserTaskFlowElement__Group__2 : rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3 ;
-    public final void rule__UserTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4__1"
+    // InternalTestgeneratorDSL.g:3804:1: rule__UserTaskFlowElement__Group_4_4__1 : rule__UserTaskFlowElement__Group_4_4__1__Impl ;
+    public final void rule__UserTaskFlowElement__Group_4_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3802:1: ( rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:3803:2: rule__UserTaskFlowElement__Group__2__Impl rule__UserTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:3808:1: ( rule__UserTaskFlowElement__Group_4_4__1__Impl )
+            // InternalTestgeneratorDSL.g:3809:2: rule__UserTaskFlowElement__Group_4_4__1__Impl
             {
-            pushFollow(FOLLOW_25);
-            rule__UserTaskFlowElement__Group__2__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__3();
+            rule__UserTaskFlowElement__Group_4_4__1__Impl();
 
             state._fsp--;
 
@@ -12064,25 +12068,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__2"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:3810:1: rule__UserTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__UserTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4__1__Impl"
+    // InternalTestgeneratorDSL.g:3815:1: rule__UserTaskFlowElement__Group_4_4__1__Impl : ( ( rule__UserTaskFlowElement__Group_4_4_1__0 )* ) ;
+    public final void rule__UserTaskFlowElement__Group_4_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3814:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:3815:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3819:1: ( ( ( rule__UserTaskFlowElement__Group_4_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:3820:1: ( ( rule__UserTaskFlowElement__Group_4_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:3815:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:3816:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:3820:1: ( ( rule__UserTaskFlowElement__Group_4_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:3821:2: ( rule__UserTaskFlowElement__Group_4_4_1__0 )*
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4_1()); 
+            // InternalTestgeneratorDSL.g:3822:2: ( rule__UserTaskFlowElement__Group_4_4_1__0 )*
+            loop29:
+            do {
+                int alt29=2;
+                int LA29_0 = input.LA(1);
+
+                if ( (LA29_0==RULE_SEPARATOR) ) {
+                    alt29=1;
+                }
+
+
+                switch (alt29) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:3822:3: rule__UserTaskFlowElement__Group_4_4_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__UserTaskFlowElement__Group_4_4_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop29;
+                }
+            } while (true);
+
+             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_4_1()); 
 
             }
 
@@ -12101,26 +12133,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:3825:1: rule__UserTaskFlowElement__Group__3 : rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4 ;
-    public final void rule__UserTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4_1__0"
+    // InternalTestgeneratorDSL.g:3831:1: rule__UserTaskFlowElement__Group_4_4_1__0 : rule__UserTaskFlowElement__Group_4_4_1__0__Impl rule__UserTaskFlowElement__Group_4_4_1__1 ;
+    public final void rule__UserTaskFlowElement__Group_4_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3829:1: ( rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:3830:2: rule__UserTaskFlowElement__Group__3__Impl rule__UserTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:3835:1: ( rule__UserTaskFlowElement__Group_4_4_1__0__Impl rule__UserTaskFlowElement__Group_4_4_1__1 )
+            // InternalTestgeneratorDSL.g:3836:2: rule__UserTaskFlowElement__Group_4_4_1__0__Impl rule__UserTaskFlowElement__Group_4_4_1__1
             {
-            pushFollow(FOLLOW_26);
-            rule__UserTaskFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_4);
+            rule__UserTaskFlowElement__Group_4_4_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__4();
+            rule__UserTaskFlowElement__Group_4_4_1__1();
 
             state._fsp--;
 
@@ -12139,25 +12171,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__3"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4_1__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:3837:1: rule__UserTaskFlowElement__Group__3__Impl : ( 'UserTask' ) ;
-    public final void rule__UserTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4_1__0__Impl"
+    // InternalTestgeneratorDSL.g:3843:1: rule__UserTaskFlowElement__Group_4_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__UserTaskFlowElement__Group_4_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3841:1: ( ( 'UserTask' ) )
-            // InternalTestgeneratorDSL.g:3842:1: ( 'UserTask' )
+            // InternalTestgeneratorDSL.g:3847:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:3848:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:3842:1: ( 'UserTask' )
-            // InternalTestgeneratorDSL.g:3843:2: 'UserTask'
+            // InternalTestgeneratorDSL.g:3848:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:3849:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); 
-            match(input,40,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0()); 
 
             }
 
@@ -12176,26 +12208,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4_1__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:3852:1: rule__UserTaskFlowElement__Group__4 : rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5 ;
-    public final void rule__UserTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4_1__1"
+    // InternalTestgeneratorDSL.g:3858:1: rule__UserTaskFlowElement__Group_4_4_1__1 : rule__UserTaskFlowElement__Group_4_4_1__1__Impl ;
+    public final void rule__UserTaskFlowElement__Group_4_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3856:1: ( rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:3857:2: rule__UserTaskFlowElement__Group__4__Impl rule__UserTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:3862:1: ( rule__UserTaskFlowElement__Group_4_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:3863:2: rule__UserTaskFlowElement__Group_4_4_1__1__Impl
             {
-            pushFollow(FOLLOW_26);
-            rule__UserTaskFlowElement__Group__4__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__5();
+            rule__UserTaskFlowElement__Group_4_4_1__1__Impl();
 
             state._fsp--;
 
@@ -12214,50 +12241,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__4"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4_1__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:3864:1: rule__UserTaskFlowElement__Group__4__Impl : ( ( rule__UserTaskFlowElement__Group_4__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_4_4_1__1__Impl"
+    // InternalTestgeneratorDSL.g:3869:1: rule__UserTaskFlowElement__Group_4_4_1__1__Impl : ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 ) ) ;
+    public final void rule__UserTaskFlowElement__Group_4_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3868:1: ( ( ( rule__UserTaskFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:3869:1: ( ( rule__UserTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:3873:1: ( ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:3874:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:3869:1: ( ( rule__UserTaskFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:3870:2: ( rule__UserTaskFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:3874:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:3875:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:3871:2: ( rule__UserTaskFlowElement__Group_4__0 )?
-            int alt29=2;
-            int LA29_0 = input.LA(1);
-
-            if ( (LA29_0==28) ) {
-                int LA29_1 = input.LA(2);
-
-                if ( (LA29_1==36) ) {
-                    alt29=1;
-                }
-            }
-            switch (alt29) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3871:3: rule__UserTaskFlowElement__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_4__0();
+             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); 
+            // InternalTestgeneratorDSL.g:3876:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 )
+            // InternalTestgeneratorDSL.g:3876:3: rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1();
 
-                    state._fsp--;
+            state._fsp--;
 
 
-                    }
-                    break;
-
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_4_4_1_1()); 
 
             }
 
@@ -12276,26 +12288,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_4_4_1__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:3879:1: rule__UserTaskFlowElement__Group__5 : rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6 ;
-    public final void rule__UserTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__0"
+    // InternalTestgeneratorDSL.g:3885:1: rule__UserTaskFlowElement__Group_5__0 : rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1 ;
+    public final void rule__UserTaskFlowElement__Group_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3883:1: ( rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:3884:2: rule__UserTaskFlowElement__Group__5__Impl rule__UserTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:3889:1: ( rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1 )
+            // InternalTestgeneratorDSL.g:3890:2: rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1
             {
-            pushFollow(FOLLOW_26);
-            rule__UserTaskFlowElement__Group__5__Impl();
+            pushFollow(FOLLOW_25);
+            rule__UserTaskFlowElement__Group_5__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__6();
+            rule__UserTaskFlowElement__Group_5__1();
 
             state._fsp--;
 
@@ -12314,50 +12326,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__5"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:3891:1: rule__UserTaskFlowElement__Group__5__Impl : ( ( rule__UserTaskFlowElement__Group_5__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__0__Impl"
+    // InternalTestgeneratorDSL.g:3897:1: rule__UserTaskFlowElement__Group_5__0__Impl : ( 'and' ) ;
+    public final void rule__UserTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3895:1: ( ( ( rule__UserTaskFlowElement__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:3896:1: ( ( rule__UserTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:3901:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:3902:1: ( 'and' )
             {
-            // InternalTestgeneratorDSL.g:3896:1: ( ( rule__UserTaskFlowElement__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:3897:2: ( rule__UserTaskFlowElement__Group_5__0 )?
+            // InternalTestgeneratorDSL.g:3902:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:3903:2: 'and'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:3898:2: ( rule__UserTaskFlowElement__Group_5__0 )?
-            int alt30=2;
-            int LA30_0 = input.LA(1);
-
-            if ( (LA30_0==28) ) {
-                int LA30_1 = input.LA(2);
-
-                if ( (LA30_1==41) ) {
-                    alt30=1;
-                }
-            }
-            switch (alt30) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3898:3: rule__UserTaskFlowElement__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_5_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_5_0()); 
 
             }
 
@@ -12376,26 +12363,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:3906:1: rule__UserTaskFlowElement__Group__6 : rule__UserTaskFlowElement__Group__6__Impl rule__UserTaskFlowElement__Group__7 ;
-    public final void rule__UserTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__1"
+    // InternalTestgeneratorDSL.g:3912:1: rule__UserTaskFlowElement__Group_5__1 : rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2 ;
+    public final void rule__UserTaskFlowElement__Group_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3910:1: ( rule__UserTaskFlowElement__Group__6__Impl rule__UserTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:3911:2: rule__UserTaskFlowElement__Group__6__Impl rule__UserTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:3916:1: ( rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2 )
+            // InternalTestgeneratorDSL.g:3917:2: rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2
             {
-            pushFollow(FOLLOW_26);
-            rule__UserTaskFlowElement__Group__6__Impl();
+            pushFollow(FOLLOW_12);
+            rule__UserTaskFlowElement__Group_5__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__7();
+            rule__UserTaskFlowElement__Group_5__2();
 
             state._fsp--;
 
@@ -12414,46 +12401,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__6"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:3918:1: rule__UserTaskFlowElement__Group__6__Impl : ( ( rule__UserTaskFlowElement__Group_6__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__1__Impl"
+    // InternalTestgeneratorDSL.g:3924:1: rule__UserTaskFlowElement__Group_5__1__Impl : ( 'label' ) ;
+    public final void rule__UserTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3922:1: ( ( ( rule__UserTaskFlowElement__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:3923:1: ( ( rule__UserTaskFlowElement__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:3928:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:3929:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:3923:1: ( ( rule__UserTaskFlowElement__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:3924:2: ( rule__UserTaskFlowElement__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:3929:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:3930:2: 'label'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:3925:2: ( rule__UserTaskFlowElement__Group_6__0 )?
-            int alt31=2;
-            int LA31_0 = input.LA(1);
-
-            if ( (LA31_0==28) ) {
-                alt31=1;
-            }
-            switch (alt31) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3925:3: rule__UserTaskFlowElement__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_6__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_5_1()); 
+            match(input,41,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_5_1()); 
 
             }
 
@@ -12472,26 +12438,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:3933:1: rule__UserTaskFlowElement__Group__7 : rule__UserTaskFlowElement__Group__7__Impl rule__UserTaskFlowElement__Group__8 ;
-    public final void rule__UserTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__2"
+    // InternalTestgeneratorDSL.g:3939:1: rule__UserTaskFlowElement__Group_5__2 : rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3 ;
+    public final void rule__UserTaskFlowElement__Group_5__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3937:1: ( rule__UserTaskFlowElement__Group__7__Impl rule__UserTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:3938:2: rule__UserTaskFlowElement__Group__7__Impl rule__UserTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:3943:1: ( rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3 )
+            // InternalTestgeneratorDSL.g:3944:2: rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3
             {
-            pushFollow(FOLLOW_26);
-            rule__UserTaskFlowElement__Group__7__Impl();
+            pushFollow(FOLLOW_7);
+            rule__UserTaskFlowElement__Group_5__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__8();
+            rule__UserTaskFlowElement__Group_5__3();
 
             state._fsp--;
 
@@ -12510,46 +12476,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__7"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:3945:1: rule__UserTaskFlowElement__Group__7__Impl : ( ( rule__UserTaskFlowElement__Group_7__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__2__Impl"
+    // InternalTestgeneratorDSL.g:3951:1: rule__UserTaskFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__UserTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3949:1: ( ( ( rule__UserTaskFlowElement__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:3950:1: ( ( rule__UserTaskFlowElement__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:3955:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:3956:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:3950:1: ( ( rule__UserTaskFlowElement__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:3951:2: ( rule__UserTaskFlowElement__Group_7__0 )?
+            // InternalTestgeneratorDSL.g:3956:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:3957:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:3952:2: ( rule__UserTaskFlowElement__Group_7__0 )?
-            int alt32=2;
-            int LA32_0 = input.LA(1);
-
-            if ( (LA32_0==43) ) {
-                alt32=1;
-            }
-            switch (alt32) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:3952:3: rule__UserTaskFlowElement__Group_7__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_7__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_7()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
 
             }
 
@@ -12568,21 +12513,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:3960:1: rule__UserTaskFlowElement__Group__8 : rule__UserTaskFlowElement__Group__8__Impl ;
-    public final void rule__UserTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__3"
+    // InternalTestgeneratorDSL.g:3966:1: rule__UserTaskFlowElement__Group_5__3 : rule__UserTaskFlowElement__Group_5__3__Impl ;
+    public final void rule__UserTaskFlowElement__Group_5__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3964:1: ( rule__UserTaskFlowElement__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:3965:2: rule__UserTaskFlowElement__Group__8__Impl
+            // InternalTestgeneratorDSL.g:3970:1: ( rule__UserTaskFlowElement__Group_5__3__Impl )
+            // InternalTestgeneratorDSL.g:3971:2: rule__UserTaskFlowElement__Group_5__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group__8__Impl();
+            rule__UserTaskFlowElement__Group_5__3__Impl();
 
             state._fsp--;
 
@@ -12601,100 +12546,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__8"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:3971:1: rule__UserTaskFlowElement__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__UserTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__Group_5__3__Impl"
+    // InternalTestgeneratorDSL.g:3977:1: rule__UserTaskFlowElement__Group_5__3__Impl : ( ( rule__UserTaskFlowElement__LabelAssignment_5_3 ) ) ;
+    public final void rule__UserTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:3975:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3976:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3981:1: ( ( ( rule__UserTaskFlowElement__LabelAssignment_5_3 ) ) )
+            // InternalTestgeneratorDSL.g:3982:1: ( ( rule__UserTaskFlowElement__LabelAssignment_5_3 ) )
             {
-            // InternalTestgeneratorDSL.g:3976:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3977:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:3982:1: ( ( rule__UserTaskFlowElement__LabelAssignment_5_3 ) )
+            // InternalTestgeneratorDSL.g:3983:2: ( rule__UserTaskFlowElement__LabelAssignment_5_3 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__UserTaskFlowElement__Group__8__Impl"
-
-
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:3987:1: rule__UserTaskFlowElement__Group_4__0 : rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1 ;
-    public final void rule__UserTaskFlowElement__Group_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:3991:1: ( rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:3992:2: rule__UserTaskFlowElement__Group_4__0__Impl rule__UserTaskFlowElement__Group_4__1
+             before(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_5_3()); 
+            // InternalTestgeneratorDSL.g:3984:2: ( rule__UserTaskFlowElement__LabelAssignment_5_3 )
+            // InternalTestgeneratorDSL.g:3984:3: rule__UserTaskFlowElement__LabelAssignment_5_3
             {
-            pushFollow(FOLLOW_19);
-            rule__UserTaskFlowElement__Group_4__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__1();
+            rule__UserTaskFlowElement__LabelAssignment_5_3();
 
             state._fsp--;
 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__0"
-
-
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:3999:1: rule__UserTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__UserTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:4003:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:4004:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:4004:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:4005:2: 'with'
-            {
-             before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_5_3()); 
 
             }
 
@@ -12713,26 +12593,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__0__Impl"
+    // $ANTLR end "rule__UserTaskFlowElement__Group_5__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:4014:1: rule__UserTaskFlowElement__Group_4__1 : rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2 ;
-    public final void rule__UserTaskFlowElement__Group_4__1() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:3993:1: rule__ManualTaskFlowElement__Group__0 : rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1 ;
+    public final void rule__ManualTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4018:1: ( rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:4019:2: rule__UserTaskFlowElement__Group_4__1__Impl rule__UserTaskFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:3997:1: ( rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:3998:2: rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1
             {
-            pushFollow(FOLLOW_20);
-            rule__UserTaskFlowElement__Group_4__1__Impl();
+            pushFollow(FOLLOW_4);
+            rule__ManualTaskFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__2();
+            rule__ManualTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -12751,25 +12631,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__1"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:4026:1: rule__UserTaskFlowElement__Group_4__1__Impl : ( 'hardcoded' ) ;
-    public final void rule__UserTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:4005:1: rule__ManualTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__ManualTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4030:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:4031:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:4009:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:4010:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:4031:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:4032:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:4010:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:4011:2: 'FlowElement'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -12788,26 +12668,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__1__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:4041:1: rule__UserTaskFlowElement__Group_4__2 : rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3 ;
-    public final void rule__UserTaskFlowElement__Group_4__2() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:4020:1: rule__ManualTaskFlowElement__Group__1 : rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2 ;
+    public final void rule__ManualTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4045:1: ( rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:4046:2: rule__UserTaskFlowElement__Group_4__2__Impl rule__UserTaskFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:4024:1: ( rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:4025:2: rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__UserTaskFlowElement__Group_4__2__Impl();
+            rule__ManualTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__3();
+            rule__ManualTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -12826,25 +12706,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__2"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:4053:1: rule__UserTaskFlowElement__Group_4__2__Impl : ( 'inputs' ) ;
-    public final void rule__UserTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:4032:1: rule__ManualTaskFlowElement__Group__1__Impl : ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__ManualTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4057:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:4058:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:4036:1: ( ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:4037:1: ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:4058:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:4059:2: 'inputs'
+            // InternalTestgeneratorDSL.g:4037:1: ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:4038:2: ( rule__ManualTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputsKeyword_4_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputsKeyword_4_2()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:4039:2: ( rule__ManualTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:4039:3: rule__ManualTaskFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__ManualTaskFlowElement__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -12863,26 +12753,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__2__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:4068:1: rule__UserTaskFlowElement__Group_4__3 : rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4 ;
-    public final void rule__UserTaskFlowElement__Group_4__3() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:4047:1: rule__ManualTaskFlowElement__Group__2 : rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3 ;
+    public final void rule__ManualTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4072:1: ( rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4 )
-            // InternalTestgeneratorDSL.g:4073:2: rule__UserTaskFlowElement__Group_4__3__Impl rule__UserTaskFlowElement__Group_4__4
+            // InternalTestgeneratorDSL.g:4051:1: ( rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:4052:2: rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3
             {
-            pushFollow(FOLLOW_13);
-            rule__UserTaskFlowElement__Group_4__3__Impl();
+            pushFollow(FOLLOW_26);
+            rule__ManualTaskFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__4();
+            rule__ManualTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -12901,25 +12791,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__3"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:4080:1: rule__UserTaskFlowElement__Group_4__3__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__UserTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:4059:1: rule__ManualTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ManualTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4084:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:4085:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4063:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4064:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4085:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:4086:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:4064:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4065:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -12938,26 +12828,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__3__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__4"
-    // InternalTestgeneratorDSL.g:4095:1: rule__UserTaskFlowElement__Group_4__4 : rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5 ;
-    public final void rule__UserTaskFlowElement__Group_4__4() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:4074:1: rule__ManualTaskFlowElement__Group__3 : rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4 ;
+    public final void rule__ManualTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4099:1: ( rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5 )
-            // InternalTestgeneratorDSL.g:4100:2: rule__UserTaskFlowElement__Group_4__4__Impl rule__UserTaskFlowElement__Group_4__5
+            // InternalTestgeneratorDSL.g:4078:1: ( rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:4079:2: rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_4__4__Impl();
+            pushFollow(FOLLOW_27);
+            rule__ManualTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__5();
+            rule__ManualTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -12976,25 +12866,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__4"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__4__Impl"
-    // InternalTestgeneratorDSL.g:4107:1: rule__UserTaskFlowElement__Group_4__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__UserTaskFlowElement__Group_4__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:4086:1: rule__ManualTaskFlowElement__Group__3__Impl : ( 'ManualTask' ) ;
+    public final void rule__ManualTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4111:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:4112:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:4090:1: ( ( 'ManualTask' ) )
+            // InternalTestgeneratorDSL.g:4091:1: ( 'ManualTask' )
             {
-            // InternalTestgeneratorDSL.g:4112:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:4113:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:4091:1: ( 'ManualTask' )
+            // InternalTestgeneratorDSL.g:4092:2: 'ManualTask'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); 
+            match(input,42,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); 
 
             }
 
@@ -13013,26 +12903,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__4__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__5"
-    // InternalTestgeneratorDSL.g:4122:1: rule__UserTaskFlowElement__Group_4__5 : rule__UserTaskFlowElement__Group_4__5__Impl rule__UserTaskFlowElement__Group_4__6 ;
-    public final void rule__UserTaskFlowElement__Group_4__5() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:4101:1: rule__ManualTaskFlowElement__Group__4 : rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5 ;
+    public final void rule__ManualTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4126:1: ( rule__UserTaskFlowElement__Group_4__5__Impl rule__UserTaskFlowElement__Group_4__6 )
-            // InternalTestgeneratorDSL.g:4127:2: rule__UserTaskFlowElement__Group_4__5__Impl rule__UserTaskFlowElement__Group_4__6
+            // InternalTestgeneratorDSL.g:4105:1: ( rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:4106:2: rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_4__5__Impl();
+            pushFollow(FOLLOW_27);
+            rule__ManualTaskFlowElement__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__6();
+            rule__ManualTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -13051,36 +12941,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__5"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__5__Impl"
-    // InternalTestgeneratorDSL.g:4134:1: rule__UserTaskFlowElement__Group_4__5__Impl : ( ( rule__UserTaskFlowElement__Group_4_5__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group_4__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:4113:1: rule__ManualTaskFlowElement__Group__4__Impl : ( ( rule__ManualTaskFlowElement__Group_4__0 )? ) ;
+    public final void rule__ManualTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4138:1: ( ( ( rule__UserTaskFlowElement__Group_4_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:4139:1: ( ( rule__UserTaskFlowElement__Group_4_5__0 )? )
+            // InternalTestgeneratorDSL.g:4117:1: ( ( ( rule__ManualTaskFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:4118:1: ( ( rule__ManualTaskFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:4139:1: ( ( rule__UserTaskFlowElement__Group_4_5__0 )? )
-            // InternalTestgeneratorDSL.g:4140:2: ( rule__UserTaskFlowElement__Group_4_5__0 )?
+            // InternalTestgeneratorDSL.g:4118:1: ( ( rule__ManualTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:4119:2: ( rule__ManualTaskFlowElement__Group_4__0 )?
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5()); 
-            // InternalTestgeneratorDSL.g:4141:2: ( rule__UserTaskFlowElement__Group_4_5__0 )?
-            int alt33=2;
-            int LA33_0 = input.LA(1);
+             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:4120:2: ( rule__ManualTaskFlowElement__Group_4__0 )?
+            int alt30=2;
+            int LA30_0 = input.LA(1);
 
-            if ( (LA33_0==RULE_ID) ) {
-                alt33=1;
+            if ( (LA30_0==40) ) {
+                alt30=1;
             }
-            switch (alt33) {
+            switch (alt30) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4141:3: rule__UserTaskFlowElement__Group_4_5__0
+                    // InternalTestgeneratorDSL.g:4120:3: rule__ManualTaskFlowElement__Group_4__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_4_5__0();
+                    rule__ManualTaskFlowElement__Group_4__0();
 
                     state._fsp--;
 
@@ -13090,7 +12980,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5()); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); 
 
             }
 
@@ -13109,21 +12999,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__5__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__6"
-    // InternalTestgeneratorDSL.g:4149:1: rule__UserTaskFlowElement__Group_4__6 : rule__UserTaskFlowElement__Group_4__6__Impl ;
-    public final void rule__UserTaskFlowElement__Group_4__6() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:4128:1: rule__ManualTaskFlowElement__Group__5 : rule__ManualTaskFlowElement__Group__5__Impl ;
+    public final void rule__ManualTaskFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4153:1: ( rule__UserTaskFlowElement__Group_4__6__Impl )
-            // InternalTestgeneratorDSL.g:4154:2: rule__UserTaskFlowElement__Group_4__6__Impl
+            // InternalTestgeneratorDSL.g:4132:1: ( rule__ManualTaskFlowElement__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:4133:2: rule__ManualTaskFlowElement__Group__5__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4__6__Impl();
+            rule__ManualTaskFlowElement__Group__5__Impl();
 
             state._fsp--;
 
@@ -13142,25 +13032,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__6"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4__6__Impl"
-    // InternalTestgeneratorDSL.g:4160:1: rule__UserTaskFlowElement__Group_4__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__UserTaskFlowElement__Group_4__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:4139:1: rule__ManualTaskFlowElement__Group__5__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__ManualTaskFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4164:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:4165:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:4143:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:4144:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:4165:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:4166:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:4144:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:4145:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
 
             }
 
@@ -13179,26 +13069,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4__6__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5__0"
-    // InternalTestgeneratorDSL.g:4176:1: rule__UserTaskFlowElement__Group_4_5__0 : rule__UserTaskFlowElement__Group_4_5__0__Impl rule__UserTaskFlowElement__Group_4_5__1 ;
-    public final void rule__UserTaskFlowElement__Group_4_5__0() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__0"
+    // InternalTestgeneratorDSL.g:4155:1: rule__ManualTaskFlowElement__Group_4__0 : rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1 ;
+    public final void rule__ManualTaskFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4180:1: ( rule__UserTaskFlowElement__Group_4_5__0__Impl rule__UserTaskFlowElement__Group_4_5__1 )
-            // InternalTestgeneratorDSL.g:4181:2: rule__UserTaskFlowElement__Group_4_5__0__Impl rule__UserTaskFlowElement__Group_4_5__1
+            // InternalTestgeneratorDSL.g:4159:1: ( rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:4160:2: rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1
             {
-            pushFollow(FOLLOW_15);
-            rule__UserTaskFlowElement__Group_4_5__0__Impl();
+            pushFollow(FOLLOW_25);
+            rule__ManualTaskFlowElement__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4_5__1();
+            rule__ManualTaskFlowElement__Group_4__1();
 
             state._fsp--;
 
@@ -13217,35 +13107,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5__0"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5__0__Impl"
-    // InternalTestgeneratorDSL.g:4188:1: rule__UserTaskFlowElement__Group_4_5__0__Impl : ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_4_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:4167:1: rule__ManualTaskFlowElement__Group_4__0__Impl : ( 'and' ) ;
+    public final void rule__ManualTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4192:1: ( ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:4193:1: ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:4193:1: ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            // InternalTestgeneratorDSL.g:4194:2: ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
+            // InternalTestgeneratorDSL.g:4171:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:4172:1: ( 'and' )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
-            // InternalTestgeneratorDSL.g:4195:2: ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
-            // InternalTestgeneratorDSL.g:4195:3: rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0
+            // InternalTestgeneratorDSL.g:4172:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:4173:2: 'and'
             {
-            pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_4_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_4_0()); 
 
             }
 
@@ -13264,21 +13144,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5__0__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5__1"
-    // InternalTestgeneratorDSL.g:4203:1: rule__UserTaskFlowElement__Group_4_5__1 : rule__UserTaskFlowElement__Group_4_5__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_4_5__1() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__1"
+    // InternalTestgeneratorDSL.g:4182:1: rule__ManualTaskFlowElement__Group_4__1 : rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2 ;
+    public final void rule__ManualTaskFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4207:1: ( rule__UserTaskFlowElement__Group_4_5__1__Impl )
-            // InternalTestgeneratorDSL.g:4208:2: rule__UserTaskFlowElement__Group_4_5__1__Impl
+            // InternalTestgeneratorDSL.g:4186:1: ( rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:4187:2: rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2
             {
+            pushFollow(FOLLOW_12);
+            rule__ManualTaskFlowElement__Group_4__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4_5__1__Impl();
+            rule__ManualTaskFlowElement__Group_4__2();
 
             state._fsp--;
 
@@ -13297,53 +13182,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5__1"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5__1__Impl"
-    // InternalTestgeneratorDSL.g:4214:1: rule__UserTaskFlowElement__Group_4_5__1__Impl : ( ( rule__UserTaskFlowElement__Group_4_5_1__0 )* ) ;
-    public final void rule__UserTaskFlowElement__Group_4_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:4194:1: rule__ManualTaskFlowElement__Group_4__1__Impl : ( 'label' ) ;
+    public final void rule__ManualTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4218:1: ( ( ( rule__UserTaskFlowElement__Group_4_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:4219:1: ( ( rule__UserTaskFlowElement__Group_4_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:4198:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:4199:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:4219:1: ( ( rule__UserTaskFlowElement__Group_4_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:4220:2: ( rule__UserTaskFlowElement__Group_4_5_1__0 )*
+            // InternalTestgeneratorDSL.g:4199:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:4200:2: 'label'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5_1()); 
-            // InternalTestgeneratorDSL.g:4221:2: ( rule__UserTaskFlowElement__Group_4_5_1__0 )*
-            loop34:
-            do {
-                int alt34=2;
-                int LA34_0 = input.LA(1);
-
-                if ( (LA34_0==RULE_SEPARATOR) ) {
-                    alt34=1;
-                }
-
-
-                switch (alt34) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:4221:3: rule__UserTaskFlowElement__Group_4_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__UserTaskFlowElement__Group_4_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop34;
-                }
-            } while (true);
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_4_5_1()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_4_1()); 
+            match(input,41,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_4_1()); 
 
             }
 
@@ -13362,26 +13219,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5__1__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5_1__0"
-    // InternalTestgeneratorDSL.g:4230:1: rule__UserTaskFlowElement__Group_4_5_1__0 : rule__UserTaskFlowElement__Group_4_5_1__0__Impl rule__UserTaskFlowElement__Group_4_5_1__1 ;
-    public final void rule__UserTaskFlowElement__Group_4_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__2"
+    // InternalTestgeneratorDSL.g:4209:1: rule__ManualTaskFlowElement__Group_4__2 : rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3 ;
+    public final void rule__ManualTaskFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4234:1: ( rule__UserTaskFlowElement__Group_4_5_1__0__Impl rule__UserTaskFlowElement__Group_4_5_1__1 )
-            // InternalTestgeneratorDSL.g:4235:2: rule__UserTaskFlowElement__Group_4_5_1__0__Impl rule__UserTaskFlowElement__Group_4_5_1__1
+            // InternalTestgeneratorDSL.g:4213:1: ( rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:4214:2: rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_4);
-            rule__UserTaskFlowElement__Group_4_5_1__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__ManualTaskFlowElement__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4_5_1__1();
+            rule__ManualTaskFlowElement__Group_4__3();
 
             state._fsp--;
 
@@ -13400,25 +13257,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5_1__0"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:4242:1: rule__UserTaskFlowElement__Group_4_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__UserTaskFlowElement__Group_4_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:4221:1: rule__ManualTaskFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ManualTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4246:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:4247:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:4225:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4226:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4247:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:4248:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:4226:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4227:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -13437,21 +13294,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5_1__0__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5_1__1"
-    // InternalTestgeneratorDSL.g:4257:1: rule__UserTaskFlowElement__Group_4_5_1__1 : rule__UserTaskFlowElement__Group_4_5_1__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_4_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__3"
+    // InternalTestgeneratorDSL.g:4236:1: rule__ManualTaskFlowElement__Group_4__3 : rule__ManualTaskFlowElement__Group_4__3__Impl ;
+    public final void rule__ManualTaskFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4261:1: ( rule__UserTaskFlowElement__Group_4_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:4262:2: rule__UserTaskFlowElement__Group_4_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:4240:1: ( rule__ManualTaskFlowElement__Group_4__3__Impl )
+            // InternalTestgeneratorDSL.g:4241:2: rule__ManualTaskFlowElement__Group_4__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_4_5_1__1__Impl();
+            rule__ManualTaskFlowElement__Group_4__3__Impl();
 
             state._fsp--;
 
@@ -13470,35 +13327,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5_1__1"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_4_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:4268:1: rule__UserTaskFlowElement__Group_4_5_1__1__Impl : ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_4_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:4247:1: rule__ManualTaskFlowElement__Group_4__3__Impl : ( ( rule__ManualTaskFlowElement__LabelAssignment_4_3 ) ) ;
+    public final void rule__ManualTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4272:1: ( ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:4273:1: ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:4251:1: ( ( ( rule__ManualTaskFlowElement__LabelAssignment_4_3 ) ) )
+            // InternalTestgeneratorDSL.g:4252:1: ( ( rule__ManualTaskFlowElement__LabelAssignment_4_3 ) )
             {
-            // InternalTestgeneratorDSL.g:4273:1: ( ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:4274:2: ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
+            // InternalTestgeneratorDSL.g:4252:1: ( ( rule__ManualTaskFlowElement__LabelAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:4253:2: ( rule__ManualTaskFlowElement__LabelAssignment_4_3 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
-            // InternalTestgeneratorDSL.g:4275:2: ( rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
-            // InternalTestgeneratorDSL.g:4275:3: rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+             before(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_4_3()); 
+            // InternalTestgeneratorDSL.g:4254:2: ( rule__ManualTaskFlowElement__LabelAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:4254:3: rule__ManualTaskFlowElement__LabelAssignment_4_3
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1();
+            rule__ManualTaskFlowElement__LabelAssignment_4_3();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_4_3()); 
 
             }
 
@@ -13517,26 +13374,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_4_5_1__1__Impl"
+    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__0"
-    // InternalTestgeneratorDSL.g:4284:1: rule__UserTaskFlowElement__Group_5__0 : rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1 ;
-    public final void rule__UserTaskFlowElement__Group_5__0() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:4263:1: rule__ScriptTaskFlowElement__Group__0 : rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1 ;
+    public final void rule__ScriptTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4288:1: ( rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1 )
-            // InternalTestgeneratorDSL.g:4289:2: rule__UserTaskFlowElement__Group_5__0__Impl rule__UserTaskFlowElement__Group_5__1
+            // InternalTestgeneratorDSL.g:4267:1: ( rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:4268:2: rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1
             {
-            pushFollow(FOLLOW_27);
-            rule__UserTaskFlowElement__Group_5__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__ScriptTaskFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__1();
+            rule__ScriptTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -13555,25 +13412,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__0"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:4296:1: rule__UserTaskFlowElement__Group_5__0__Impl : ( 'with' ) ;
-    public final void rule__UserTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:4275:1: rule__ScriptTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__ScriptTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4300:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:4301:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:4279:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:4280:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:4301:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:4302:2: 'with'
+            // InternalTestgeneratorDSL.g:4280:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:4281:2: 'FlowElement'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_5_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_5_0()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -13592,26 +13449,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__0__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__1"
-    // InternalTestgeneratorDSL.g:4311:1: rule__UserTaskFlowElement__Group_5__1 : rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2 ;
-    public final void rule__UserTaskFlowElement__Group_5__1() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:4290:1: rule__ScriptTaskFlowElement__Group__1 : rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2 ;
+    public final void rule__ScriptTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4315:1: ( rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2 )
-            // InternalTestgeneratorDSL.g:4316:2: rule__UserTaskFlowElement__Group_5__1__Impl rule__UserTaskFlowElement__Group_5__2
+            // InternalTestgeneratorDSL.g:4294:1: ( rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:4295:2: rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__UserTaskFlowElement__Group_5__1__Impl();
+            rule__ScriptTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__2();
+            rule__ScriptTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -13630,25 +13487,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__1"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:4323:1: rule__UserTaskFlowElement__Group_5__1__Impl : ( 'inputVariables' ) ;
-    public final void rule__UserTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:4302:1: rule__ScriptTaskFlowElement__Group__1__Impl : ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__ScriptTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4327:1: ( ( 'inputVariables' ) )
-            // InternalTestgeneratorDSL.g:4328:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:4306:1: ( ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:4307:1: ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:4328:1: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:4329:2: 'inputVariables'
+            // InternalTestgeneratorDSL.g:4307:1: ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:4308:2: ( rule__ScriptTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
-            match(input,41,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:4309:2: ( rule__ScriptTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:4309:3: rule__ScriptTaskFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__ScriptTaskFlowElement__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -13667,26 +13534,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__1__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__2"
-    // InternalTestgeneratorDSL.g:4338:1: rule__UserTaskFlowElement__Group_5__2 : rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3 ;
-    public final void rule__UserTaskFlowElement__Group_5__2() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:4317:1: rule__ScriptTaskFlowElement__Group__2 : rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3 ;
+    public final void rule__ScriptTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4342:1: ( rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3 )
-            // InternalTestgeneratorDSL.g:4343:2: rule__UserTaskFlowElement__Group_5__2__Impl rule__UserTaskFlowElement__Group_5__3
+            // InternalTestgeneratorDSL.g:4321:1: ( rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:4322:2: rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3
             {
-            pushFollow(FOLLOW_13);
-            rule__UserTaskFlowElement__Group_5__2__Impl();
+            pushFollow(FOLLOW_28);
+            rule__ScriptTaskFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__3();
+            rule__ScriptTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -13705,25 +13572,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__2"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__2__Impl"
-    // InternalTestgeneratorDSL.g:4350:1: rule__UserTaskFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__UserTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:4329:1: rule__ScriptTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ScriptTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4354:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:4355:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4333:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4334:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4355:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:4356:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:4334:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4335:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -13742,26 +13609,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__2__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__3"
-    // InternalTestgeneratorDSL.g:4365:1: rule__UserTaskFlowElement__Group_5__3 : rule__UserTaskFlowElement__Group_5__3__Impl rule__UserTaskFlowElement__Group_5__4 ;
-    public final void rule__UserTaskFlowElement__Group_5__3() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:4344:1: rule__ScriptTaskFlowElement__Group__3 : rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4 ;
+    public final void rule__ScriptTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4369:1: ( rule__UserTaskFlowElement__Group_5__3__Impl rule__UserTaskFlowElement__Group_5__4 )
-            // InternalTestgeneratorDSL.g:4370:2: rule__UserTaskFlowElement__Group_5__3__Impl rule__UserTaskFlowElement__Group_5__4
+            // InternalTestgeneratorDSL.g:4348:1: ( rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:4349:2: rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_5__3__Impl();
+            pushFollow(FOLLOW_27);
+            rule__ScriptTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__4();
+            rule__ScriptTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -13780,25 +13647,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__3"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__3__Impl"
-    // InternalTestgeneratorDSL.g:4377:1: rule__UserTaskFlowElement__Group_5__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__UserTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:4356:1: rule__ScriptTaskFlowElement__Group__3__Impl : ( 'ScriptTask' ) ;
+    public final void rule__ScriptTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4381:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:4382:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:4360:1: ( ( 'ScriptTask' ) )
+            // InternalTestgeneratorDSL.g:4361:1: ( 'ScriptTask' )
             {
-            // InternalTestgeneratorDSL.g:4382:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:4383:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:4361:1: ( 'ScriptTask' )
+            // InternalTestgeneratorDSL.g:4362:2: 'ScriptTask'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); 
+            match(input,43,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); 
 
             }
 
@@ -13817,26 +13684,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__3__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__4"
-    // InternalTestgeneratorDSL.g:4392:1: rule__UserTaskFlowElement__Group_5__4 : rule__UserTaskFlowElement__Group_5__4__Impl rule__UserTaskFlowElement__Group_5__5 ;
-    public final void rule__UserTaskFlowElement__Group_5__4() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:4371:1: rule__ScriptTaskFlowElement__Group__4 : rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5 ;
+    public final void rule__ScriptTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4396:1: ( rule__UserTaskFlowElement__Group_5__4__Impl rule__UserTaskFlowElement__Group_5__5 )
-            // InternalTestgeneratorDSL.g:4397:2: rule__UserTaskFlowElement__Group_5__4__Impl rule__UserTaskFlowElement__Group_5__5
+            // InternalTestgeneratorDSL.g:4375:1: ( rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:4376:2: rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_5__4__Impl();
+            pushFollow(FOLLOW_27);
+            rule__ScriptTaskFlowElement__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__5();
+            rule__ScriptTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -13855,36 +13722,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__4"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__4__Impl"
-    // InternalTestgeneratorDSL.g:4404:1: rule__UserTaskFlowElement__Group_5__4__Impl : ( ( rule__UserTaskFlowElement__Group_5_4__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group_5__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:4383:1: rule__ScriptTaskFlowElement__Group__4__Impl : ( ( rule__ScriptTaskFlowElement__Group_4__0 )? ) ;
+    public final void rule__ScriptTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4408:1: ( ( ( rule__UserTaskFlowElement__Group_5_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:4409:1: ( ( rule__UserTaskFlowElement__Group_5_4__0 )? )
+            // InternalTestgeneratorDSL.g:4387:1: ( ( ( rule__ScriptTaskFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:4388:1: ( ( rule__ScriptTaskFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:4409:1: ( ( rule__UserTaskFlowElement__Group_5_4__0 )? )
-            // InternalTestgeneratorDSL.g:4410:2: ( rule__UserTaskFlowElement__Group_5_4__0 )?
+            // InternalTestgeneratorDSL.g:4388:1: ( ( rule__ScriptTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:4389:2: ( rule__ScriptTaskFlowElement__Group_4__0 )?
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4()); 
-            // InternalTestgeneratorDSL.g:4411:2: ( rule__UserTaskFlowElement__Group_5_4__0 )?
-            int alt35=2;
-            int LA35_0 = input.LA(1);
+             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:4390:2: ( rule__ScriptTaskFlowElement__Group_4__0 )?
+            int alt31=2;
+            int LA31_0 = input.LA(1);
 
-            if ( (LA35_0==RULE_ID) ) {
-                alt35=1;
+            if ( (LA31_0==40) ) {
+                alt31=1;
             }
-            switch (alt35) {
+            switch (alt31) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4411:3: rule__UserTaskFlowElement__Group_5_4__0
+                    // InternalTestgeneratorDSL.g:4390:3: rule__ScriptTaskFlowElement__Group_4__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_5_4__0();
+                    rule__ScriptTaskFlowElement__Group_4__0();
 
                     state._fsp--;
 
@@ -13894,7 +13761,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4()); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); 
 
             }
 
@@ -13913,21 +13780,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__4__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__5"
-    // InternalTestgeneratorDSL.g:4419:1: rule__UserTaskFlowElement__Group_5__5 : rule__UserTaskFlowElement__Group_5__5__Impl ;
-    public final void rule__UserTaskFlowElement__Group_5__5() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:4398:1: rule__ScriptTaskFlowElement__Group__5 : rule__ScriptTaskFlowElement__Group__5__Impl ;
+    public final void rule__ScriptTaskFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4423:1: ( rule__UserTaskFlowElement__Group_5__5__Impl )
-            // InternalTestgeneratorDSL.g:4424:2: rule__UserTaskFlowElement__Group_5__5__Impl
+            // InternalTestgeneratorDSL.g:4402:1: ( rule__ScriptTaskFlowElement__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:4403:2: rule__ScriptTaskFlowElement__Group__5__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5__5__Impl();
+            rule__ScriptTaskFlowElement__Group__5__Impl();
 
             state._fsp--;
 
@@ -13946,25 +13813,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__5"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5__5__Impl"
-    // InternalTestgeneratorDSL.g:4430:1: rule__UserTaskFlowElement__Group_5__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__UserTaskFlowElement__Group_5__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:4409:1: rule__ScriptTaskFlowElement__Group__5__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__ScriptTaskFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4434:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:4435:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:4413:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:4414:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:4435:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:4436:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:4414:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:4415:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
 
             }
 
@@ -13983,26 +13850,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5__5__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4__0"
-    // InternalTestgeneratorDSL.g:4446:1: rule__UserTaskFlowElement__Group_5_4__0 : rule__UserTaskFlowElement__Group_5_4__0__Impl rule__UserTaskFlowElement__Group_5_4__1 ;
-    public final void rule__UserTaskFlowElement__Group_5_4__0() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__0"
+    // InternalTestgeneratorDSL.g:4425:1: rule__ScriptTaskFlowElement__Group_4__0 : rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1 ;
+    public final void rule__ScriptTaskFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4450:1: ( rule__UserTaskFlowElement__Group_5_4__0__Impl rule__UserTaskFlowElement__Group_5_4__1 )
-            // InternalTestgeneratorDSL.g:4451:2: rule__UserTaskFlowElement__Group_5_4__0__Impl rule__UserTaskFlowElement__Group_5_4__1
+            // InternalTestgeneratorDSL.g:4429:1: ( rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:4430:2: rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1
             {
-            pushFollow(FOLLOW_15);
-            rule__UserTaskFlowElement__Group_5_4__0__Impl();
+            pushFollow(FOLLOW_25);
+            rule__ScriptTaskFlowElement__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5_4__1();
+            rule__ScriptTaskFlowElement__Group_4__1();
 
             state._fsp--;
 
@@ -14021,35 +13888,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4__0"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4__0__Impl"
-    // InternalTestgeneratorDSL.g:4458:1: rule__UserTaskFlowElement__Group_5_4__0__Impl : ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_5_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:4437:1: rule__ScriptTaskFlowElement__Group_4__0__Impl : ( 'and' ) ;
+    public final void rule__ScriptTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4462:1: ( ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:4463:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
+            // InternalTestgeneratorDSL.g:4441:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:4442:1: ( 'and' )
             {
-            // InternalTestgeneratorDSL.g:4463:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
-            // InternalTestgeneratorDSL.g:4464:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 )
+            // InternalTestgeneratorDSL.g:4442:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:4443:2: 'and'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
-            // InternalTestgeneratorDSL.g:4465:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 )
-            // InternalTestgeneratorDSL.g:4465:3: rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_4_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_4_0()); 
 
             }
 
@@ -14068,21 +13925,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4__0__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4__1"
-    // InternalTestgeneratorDSL.g:4473:1: rule__UserTaskFlowElement__Group_5_4__1 : rule__UserTaskFlowElement__Group_5_4__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_5_4__1() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__1"
+    // InternalTestgeneratorDSL.g:4452:1: rule__ScriptTaskFlowElement__Group_4__1 : rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2 ;
+    public final void rule__ScriptTaskFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4477:1: ( rule__UserTaskFlowElement__Group_5_4__1__Impl )
-            // InternalTestgeneratorDSL.g:4478:2: rule__UserTaskFlowElement__Group_5_4__1__Impl
+            // InternalTestgeneratorDSL.g:4456:1: ( rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:4457:2: rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2
             {
+            pushFollow(FOLLOW_12);
+            rule__ScriptTaskFlowElement__Group_4__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5_4__1__Impl();
+            rule__ScriptTaskFlowElement__Group_4__2();
 
             state._fsp--;
 
@@ -14101,53 +13963,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4__1"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4__1__Impl"
-    // InternalTestgeneratorDSL.g:4484:1: rule__UserTaskFlowElement__Group_5_4__1__Impl : ( ( rule__UserTaskFlowElement__Group_5_4_1__0 )* ) ;
-    public final void rule__UserTaskFlowElement__Group_5_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:4464:1: rule__ScriptTaskFlowElement__Group_4__1__Impl : ( 'label' ) ;
+    public final void rule__ScriptTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4488:1: ( ( ( rule__UserTaskFlowElement__Group_5_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:4489:1: ( ( rule__UserTaskFlowElement__Group_5_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:4468:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:4469:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:4489:1: ( ( rule__UserTaskFlowElement__Group_5_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:4490:2: ( rule__UserTaskFlowElement__Group_5_4_1__0 )*
+            // InternalTestgeneratorDSL.g:4469:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:4470:2: 'label'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4_1()); 
-            // InternalTestgeneratorDSL.g:4491:2: ( rule__UserTaskFlowElement__Group_5_4_1__0 )*
-            loop36:
-            do {
-                int alt36=2;
-                int LA36_0 = input.LA(1);
-
-                if ( (LA36_0==RULE_SEPARATOR) ) {
-                    alt36=1;
-                }
-
-
-                switch (alt36) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:4491:3: rule__UserTaskFlowElement__Group_5_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__UserTaskFlowElement__Group_5_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop36;
-                }
-            } while (true);
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_5_4_1()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_4_1()); 
+            match(input,41,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_4_1()); 
 
             }
 
@@ -14166,26 +14000,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4__1__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4_1__0"
-    // InternalTestgeneratorDSL.g:4500:1: rule__UserTaskFlowElement__Group_5_4_1__0 : rule__UserTaskFlowElement__Group_5_4_1__0__Impl rule__UserTaskFlowElement__Group_5_4_1__1 ;
-    public final void rule__UserTaskFlowElement__Group_5_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__2"
+    // InternalTestgeneratorDSL.g:4479:1: rule__ScriptTaskFlowElement__Group_4__2 : rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3 ;
+    public final void rule__ScriptTaskFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4504:1: ( rule__UserTaskFlowElement__Group_5_4_1__0__Impl rule__UserTaskFlowElement__Group_5_4_1__1 )
-            // InternalTestgeneratorDSL.g:4505:2: rule__UserTaskFlowElement__Group_5_4_1__0__Impl rule__UserTaskFlowElement__Group_5_4_1__1
+            // InternalTestgeneratorDSL.g:4483:1: ( rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:4484:2: rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_4);
-            rule__UserTaskFlowElement__Group_5_4_1__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__ScriptTaskFlowElement__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5_4_1__1();
+            rule__ScriptTaskFlowElement__Group_4__3();
 
             state._fsp--;
 
@@ -14204,25 +14038,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4_1__0"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:4512:1: rule__UserTaskFlowElement__Group_5_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__UserTaskFlowElement__Group_5_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:4491:1: rule__ScriptTaskFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ScriptTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4516:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:4517:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:4495:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4496:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4517:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:4518:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:4496:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4497:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -14241,21 +14075,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4_1__0__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4_1__1"
-    // InternalTestgeneratorDSL.g:4527:1: rule__UserTaskFlowElement__Group_5_4_1__1 : rule__UserTaskFlowElement__Group_5_4_1__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_5_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__3"
+    // InternalTestgeneratorDSL.g:4506:1: rule__ScriptTaskFlowElement__Group_4__3 : rule__ScriptTaskFlowElement__Group_4__3__Impl ;
+    public final void rule__ScriptTaskFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4531:1: ( rule__UserTaskFlowElement__Group_5_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:4532:2: rule__UserTaskFlowElement__Group_5_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:4510:1: ( rule__ScriptTaskFlowElement__Group_4__3__Impl )
+            // InternalTestgeneratorDSL.g:4511:2: rule__ScriptTaskFlowElement__Group_4__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_5_4_1__1__Impl();
+            rule__ScriptTaskFlowElement__Group_4__3__Impl();
 
             state._fsp--;
 
@@ -14274,35 +14108,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4_1__1"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_5_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:4538:1: rule__UserTaskFlowElement__Group_5_4_1__1__Impl : ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_5_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:4517:1: rule__ScriptTaskFlowElement__Group_4__3__Impl : ( ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 ) ) ;
+    public final void rule__ScriptTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4542:1: ( ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:4543:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:4521:1: ( ( ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 ) ) )
+            // InternalTestgeneratorDSL.g:4522:1: ( ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 ) )
             {
-            // InternalTestgeneratorDSL.g:4543:1: ( ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:4544:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
+            // InternalTestgeneratorDSL.g:4522:1: ( ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:4523:2: ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
-            // InternalTestgeneratorDSL.g:4545:2: ( rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
-            // InternalTestgeneratorDSL.g:4545:3: rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1
+             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_4_3()); 
+            // InternalTestgeneratorDSL.g:4524:2: ( rule__ScriptTaskFlowElement__LabelAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:4524:3: rule__ScriptTaskFlowElement__LabelAssignment_4_3
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1();
+            rule__ScriptTaskFlowElement__LabelAssignment_4_3();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_4_3()); 
 
             }
 
@@ -14321,26 +14155,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_5_4_1__1__Impl"
+    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__0"
-    // InternalTestgeneratorDSL.g:4554:1: rule__UserTaskFlowElement__Group_6__0 : rule__UserTaskFlowElement__Group_6__0__Impl rule__UserTaskFlowElement__Group_6__1 ;
-    public final void rule__UserTaskFlowElement__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:4533:1: rule__DelegateServiceTaskFlowElement__Group__0 : rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4558:1: ( rule__UserTaskFlowElement__Group_6__0__Impl rule__UserTaskFlowElement__Group_6__1 )
-            // InternalTestgeneratorDSL.g:4559:2: rule__UserTaskFlowElement__Group_6__0__Impl rule__UserTaskFlowElement__Group_6__1
+            // InternalTestgeneratorDSL.g:4537:1: ( rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:4538:2: rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1
             {
-            pushFollow(FOLLOW_28);
-            rule__UserTaskFlowElement__Group_6__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__DelegateServiceTaskFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__1();
+            rule__DelegateServiceTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -14359,25 +14193,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__0"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:4566:1: rule__UserTaskFlowElement__Group_6__0__Impl : ( 'with' ) ;
-    public final void rule__UserTaskFlowElement__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:4545:1: rule__DelegateServiceTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4570:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:4571:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:4549:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:4550:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:4571:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:4572:2: 'with'
+            // InternalTestgeneratorDSL.g:4550:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:4551:2: 'FlowElement'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_6_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_6_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -14396,26 +14230,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__0__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__1"
-    // InternalTestgeneratorDSL.g:4581:1: rule__UserTaskFlowElement__Group_6__1 : rule__UserTaskFlowElement__Group_6__1__Impl rule__UserTaskFlowElement__Group_6__2 ;
-    public final void rule__UserTaskFlowElement__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:4560:1: rule__DelegateServiceTaskFlowElement__Group__1 : rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4585:1: ( rule__UserTaskFlowElement__Group_6__1__Impl rule__UserTaskFlowElement__Group_6__2 )
-            // InternalTestgeneratorDSL.g:4586:2: rule__UserTaskFlowElement__Group_6__1__Impl rule__UserTaskFlowElement__Group_6__2
+            // InternalTestgeneratorDSL.g:4564:1: ( rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:4565:2: rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__UserTaskFlowElement__Group_6__1__Impl();
+            rule__DelegateServiceTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__2();
+            rule__DelegateServiceTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -14434,25 +14268,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:4593:1: rule__UserTaskFlowElement__Group_6__1__Impl : ( 'outputVariables' ) ;
-    public final void rule__UserTaskFlowElement__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:4572:1: rule__DelegateServiceTaskFlowElement__Group__1__Impl : ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4597:1: ( ( 'outputVariables' ) )
-            // InternalTestgeneratorDSL.g:4598:1: ( 'outputVariables' )
+            // InternalTestgeneratorDSL.g:4576:1: ( ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:4577:1: ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:4598:1: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:4599:2: 'outputVariables'
+            // InternalTestgeneratorDSL.g:4577:1: ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:4578:2: ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
-            match(input,42,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:4579:2: ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:4579:3: rule__DelegateServiceTaskFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__DelegateServiceTaskFlowElement__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -14471,26 +14315,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__1__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__2"
-    // InternalTestgeneratorDSL.g:4608:1: rule__UserTaskFlowElement__Group_6__2 : rule__UserTaskFlowElement__Group_6__2__Impl rule__UserTaskFlowElement__Group_6__3 ;
-    public final void rule__UserTaskFlowElement__Group_6__2() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:4587:1: rule__DelegateServiceTaskFlowElement__Group__2 : rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4612:1: ( rule__UserTaskFlowElement__Group_6__2__Impl rule__UserTaskFlowElement__Group_6__3 )
-            // InternalTestgeneratorDSL.g:4613:2: rule__UserTaskFlowElement__Group_6__2__Impl rule__UserTaskFlowElement__Group_6__3
+            // InternalTestgeneratorDSL.g:4591:1: ( rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:4592:2: rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3
             {
-            pushFollow(FOLLOW_13);
-            rule__UserTaskFlowElement__Group_6__2__Impl();
+            pushFollow(FOLLOW_29);
+            rule__DelegateServiceTaskFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__3();
+            rule__DelegateServiceTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -14509,25 +14353,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__2"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__2__Impl"
-    // InternalTestgeneratorDSL.g:4620:1: rule__UserTaskFlowElement__Group_6__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__UserTaskFlowElement__Group_6__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:4599:1: rule__DelegateServiceTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4624:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:4625:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4603:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4604:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4625:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:4626:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:4604:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4605:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -14546,26 +14390,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__2__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__3"
-    // InternalTestgeneratorDSL.g:4635:1: rule__UserTaskFlowElement__Group_6__3 : rule__UserTaskFlowElement__Group_6__3__Impl rule__UserTaskFlowElement__Group_6__4 ;
-    public final void rule__UserTaskFlowElement__Group_6__3() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:4614:1: rule__DelegateServiceTaskFlowElement__Group__3 : rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4639:1: ( rule__UserTaskFlowElement__Group_6__3__Impl rule__UserTaskFlowElement__Group_6__4 )
-            // InternalTestgeneratorDSL.g:4640:2: rule__UserTaskFlowElement__Group_6__3__Impl rule__UserTaskFlowElement__Group_6__4
+            // InternalTestgeneratorDSL.g:4618:1: ( rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:4619:2: rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_6__3__Impl();
+            pushFollow(FOLLOW_5);
+            rule__DelegateServiceTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__4();
+            rule__DelegateServiceTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -14584,25 +14428,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__3"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__3__Impl"
-    // InternalTestgeneratorDSL.g:4647:1: rule__UserTaskFlowElement__Group_6__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__UserTaskFlowElement__Group_6__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:4626:1: rule__DelegateServiceTaskFlowElement__Group__3__Impl : ( 'ServiceTask' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4651:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:4652:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:4630:1: ( ( 'ServiceTask' ) )
+            // InternalTestgeneratorDSL.g:4631:1: ( 'ServiceTask' )
             {
-            // InternalTestgeneratorDSL.g:4652:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:4653:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:4631:1: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:4632:2: 'ServiceTask'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
+            match(input,44,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
 
             }
 
@@ -14621,26 +14465,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__3__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__4"
-    // InternalTestgeneratorDSL.g:4662:1: rule__UserTaskFlowElement__Group_6__4 : rule__UserTaskFlowElement__Group_6__4__Impl rule__UserTaskFlowElement__Group_6__5 ;
-    public final void rule__UserTaskFlowElement__Group_6__4() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:4641:1: rule__DelegateServiceTaskFlowElement__Group__4 : rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4666:1: ( rule__UserTaskFlowElement__Group_6__4__Impl rule__UserTaskFlowElement__Group_6__5 )
-            // InternalTestgeneratorDSL.g:4667:2: rule__UserTaskFlowElement__Group_6__4__Impl rule__UserTaskFlowElement__Group_6__5
+            // InternalTestgeneratorDSL.g:4645:1: ( rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:4646:2: rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5
             {
-            pushFollow(FOLLOW_21);
-            rule__UserTaskFlowElement__Group_6__4__Impl();
+            pushFollow(FOLLOW_30);
+            rule__DelegateServiceTaskFlowElement__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__5();
+            rule__DelegateServiceTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -14659,46 +14503,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__4"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__4__Impl"
-    // InternalTestgeneratorDSL.g:4674:1: rule__UserTaskFlowElement__Group_6__4__Impl : ( ( rule__UserTaskFlowElement__Group_6_4__0 )? ) ;
-    public final void rule__UserTaskFlowElement__Group_6__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:4653:1: rule__DelegateServiceTaskFlowElement__Group__4__Impl : ( 'with' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4678:1: ( ( ( rule__UserTaskFlowElement__Group_6_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:4679:1: ( ( rule__UserTaskFlowElement__Group_6_4__0 )? )
+            // InternalTestgeneratorDSL.g:4657:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:4658:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:4679:1: ( ( rule__UserTaskFlowElement__Group_6_4__0 )? )
-            // InternalTestgeneratorDSL.g:4680:2: ( rule__UserTaskFlowElement__Group_6_4__0 )?
+            // InternalTestgeneratorDSL.g:4658:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:4659:2: 'with'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4()); 
-            // InternalTestgeneratorDSL.g:4681:2: ( rule__UserTaskFlowElement__Group_6_4__0 )?
-            int alt37=2;
-            int LA37_0 = input.LA(1);
-
-            if ( (LA37_0==RULE_ID) ) {
-                alt37=1;
-            }
-            switch (alt37) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:4681:3: rule__UserTaskFlowElement__Group_6_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__UserTaskFlowElement__Group_6_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); 
 
             }
 
@@ -14717,21 +14540,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__4__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__5"
-    // InternalTestgeneratorDSL.g:4689:1: rule__UserTaskFlowElement__Group_6__5 : rule__UserTaskFlowElement__Group_6__5__Impl ;
-    public final void rule__UserTaskFlowElement__Group_6__5() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:4668:1: rule__DelegateServiceTaskFlowElement__Group__5 : rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4693:1: ( rule__UserTaskFlowElement__Group_6__5__Impl )
-            // InternalTestgeneratorDSL.g:4694:2: rule__UserTaskFlowElement__Group_6__5__Impl
+            // InternalTestgeneratorDSL.g:4672:1: ( rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6 )
+            // InternalTestgeneratorDSL.g:4673:2: rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6
             {
+            pushFollow(FOLLOW_12);
+            rule__DelegateServiceTaskFlowElement__Group__5__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6__5__Impl();
+            rule__DelegateServiceTaskFlowElement__Group__6();
 
             state._fsp--;
 
@@ -14750,25 +14578,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__5"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6__5__Impl"
-    // InternalTestgeneratorDSL.g:4700:1: rule__UserTaskFlowElement__Group_6__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__UserTaskFlowElement__Group_6__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:4680:1: rule__DelegateServiceTaskFlowElement__Group__5__Impl : ( 'delegate' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4704:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:4705:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:4684:1: ( ( 'delegate' ) )
+            // InternalTestgeneratorDSL.g:4685:1: ( 'delegate' )
             {
-            // InternalTestgeneratorDSL.g:4705:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:4706:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:4685:1: ( 'delegate' )
+            // InternalTestgeneratorDSL.g:4686:2: 'delegate'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); 
+            match(input,45,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); 
 
             }
 
@@ -14787,26 +14615,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6__5__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4__0"
-    // InternalTestgeneratorDSL.g:4716:1: rule__UserTaskFlowElement__Group_6_4__0 : rule__UserTaskFlowElement__Group_6_4__0__Impl rule__UserTaskFlowElement__Group_6_4__1 ;
-    public final void rule__UserTaskFlowElement__Group_6_4__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__6"
+    // InternalTestgeneratorDSL.g:4695:1: rule__DelegateServiceTaskFlowElement__Group__6 : rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4720:1: ( rule__UserTaskFlowElement__Group_6_4__0__Impl rule__UserTaskFlowElement__Group_6_4__1 )
-            // InternalTestgeneratorDSL.g:4721:2: rule__UserTaskFlowElement__Group_6_4__0__Impl rule__UserTaskFlowElement__Group_6_4__1
+            // InternalTestgeneratorDSL.g:4699:1: ( rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7 )
+            // InternalTestgeneratorDSL.g:4700:2: rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7
             {
-            pushFollow(FOLLOW_15);
-            rule__UserTaskFlowElement__Group_6_4__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__DelegateServiceTaskFlowElement__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6_4__1();
+            rule__DelegateServiceTaskFlowElement__Group__7();
 
             state._fsp--;
 
@@ -14825,35 +14653,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4__0"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__6"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4__0__Impl"
-    // InternalTestgeneratorDSL.g:4728:1: rule__UserTaskFlowElement__Group_6_4__0__Impl : ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_6_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:4707:1: rule__DelegateServiceTaskFlowElement__Group__6__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4732:1: ( ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:4733:1: ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
+            // InternalTestgeneratorDSL.g:4711:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4712:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4733:1: ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
-            // InternalTestgeneratorDSL.g:4734:2: ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 )
+            // InternalTestgeneratorDSL.g:4712:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4713:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
-            // InternalTestgeneratorDSL.g:4735:2: ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 )
-            // InternalTestgeneratorDSL.g:4735:3: rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
 
             }
 
@@ -14872,21 +14690,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4__0__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__6__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4__1"
-    // InternalTestgeneratorDSL.g:4743:1: rule__UserTaskFlowElement__Group_6_4__1 : rule__UserTaskFlowElement__Group_6_4__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_6_4__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__7"
+    // InternalTestgeneratorDSL.g:4722:1: rule__DelegateServiceTaskFlowElement__Group__7 : rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4747:1: ( rule__UserTaskFlowElement__Group_6_4__1__Impl )
-            // InternalTestgeneratorDSL.g:4748:2: rule__UserTaskFlowElement__Group_6_4__1__Impl
+            // InternalTestgeneratorDSL.g:4726:1: ( rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8 )
+            // InternalTestgeneratorDSL.g:4727:2: rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8
             {
+            pushFollow(FOLLOW_27);
+            rule__DelegateServiceTaskFlowElement__Group__7__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6_4__1__Impl();
+            rule__DelegateServiceTaskFlowElement__Group__8();
 
             state._fsp--;
 
@@ -14905,53 +14728,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4__1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__7"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4__1__Impl"
-    // InternalTestgeneratorDSL.g:4754:1: rule__UserTaskFlowElement__Group_6_4__1__Impl : ( ( rule__UserTaskFlowElement__Group_6_4_1__0 )* ) ;
-    public final void rule__UserTaskFlowElement__Group_6_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:4734:1: rule__DelegateServiceTaskFlowElement__Group__7__Impl : ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4758:1: ( ( ( rule__UserTaskFlowElement__Group_6_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:4759:1: ( ( rule__UserTaskFlowElement__Group_6_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:4738:1: ( ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) ) )
+            // InternalTestgeneratorDSL.g:4739:1: ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) )
             {
-            // InternalTestgeneratorDSL.g:4759:1: ( ( rule__UserTaskFlowElement__Group_6_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:4760:2: ( rule__UserTaskFlowElement__Group_6_4_1__0 )*
+            // InternalTestgeneratorDSL.g:4739:1: ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:4740:2: ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4_1()); 
-            // InternalTestgeneratorDSL.g:4761:2: ( rule__UserTaskFlowElement__Group_6_4_1__0 )*
-            loop38:
-            do {
-                int alt38=2;
-                int LA38_0 = input.LA(1);
-
-                if ( (LA38_0==RULE_SEPARATOR) ) {
-                    alt38=1;
-                }
-
-
-                switch (alt38) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:4761:3: rule__UserTaskFlowElement__Group_6_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__UserTaskFlowElement__Group_6_4_1__0();
-
-            	    state._fsp--;
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); 
+            // InternalTestgeneratorDSL.g:4741:2: ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 )
+            // InternalTestgeneratorDSL.g:4741:3: rule__DelegateServiceTaskFlowElement__DelegateAssignment_7
+            {
+            pushFollow(FOLLOW_2);
+            rule__DelegateServiceTaskFlowElement__DelegateAssignment_7();
 
+            state._fsp--;
 
-            	    }
-            	    break;
 
-            	default :
-            	    break loop38;
-                }
-            } while (true);
+            }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getGroup_6_4_1()); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); 
 
             }
 
@@ -14970,26 +14775,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4__1__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__7__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4_1__0"
-    // InternalTestgeneratorDSL.g:4770:1: rule__UserTaskFlowElement__Group_6_4_1__0 : rule__UserTaskFlowElement__Group_6_4_1__0__Impl rule__UserTaskFlowElement__Group_6_4_1__1 ;
-    public final void rule__UserTaskFlowElement__Group_6_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__8"
+    // InternalTestgeneratorDSL.g:4749:1: rule__DelegateServiceTaskFlowElement__Group__8 : rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4774:1: ( rule__UserTaskFlowElement__Group_6_4_1__0__Impl rule__UserTaskFlowElement__Group_6_4_1__1 )
-            // InternalTestgeneratorDSL.g:4775:2: rule__UserTaskFlowElement__Group_6_4_1__0__Impl rule__UserTaskFlowElement__Group_6_4_1__1
+            // InternalTestgeneratorDSL.g:4753:1: ( rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9 )
+            // InternalTestgeneratorDSL.g:4754:2: rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9
             {
-            pushFollow(FOLLOW_4);
-            rule__UserTaskFlowElement__Group_6_4_1__0__Impl();
+            pushFollow(FOLLOW_27);
+            rule__DelegateServiceTaskFlowElement__Group__8__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6_4_1__1();
+            rule__DelegateServiceTaskFlowElement__Group__9();
 
             state._fsp--;
 
@@ -15008,25 +14813,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4_1__0"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__8"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:4782:1: rule__UserTaskFlowElement__Group_6_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__UserTaskFlowElement__Group_6_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:4761:1: rule__DelegateServiceTaskFlowElement__Group__8__Impl : ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4786:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:4787:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:4765:1: ( ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? ) )
+            // InternalTestgeneratorDSL.g:4766:1: ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? )
             {
-            // InternalTestgeneratorDSL.g:4787:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:4788:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:4766:1: ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? )
+            // InternalTestgeneratorDSL.g:4767:2: ( rule__DelegateServiceTaskFlowElement__Group_8__0 )?
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); 
+            // InternalTestgeneratorDSL.g:4768:2: ( rule__DelegateServiceTaskFlowElement__Group_8__0 )?
+            int alt32=2;
+            int LA32_0 = input.LA(1);
+
+            if ( (LA32_0==40) ) {
+                alt32=1;
+            }
+            switch (alt32) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:4768:3: rule__DelegateServiceTaskFlowElement__Group_8__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__DelegateServiceTaskFlowElement__Group_8__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); 
 
             }
 
@@ -15045,21 +14871,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4_1__0__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__8__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4_1__1"
-    // InternalTestgeneratorDSL.g:4797:1: rule__UserTaskFlowElement__Group_6_4_1__1 : rule__UserTaskFlowElement__Group_6_4_1__1__Impl ;
-    public final void rule__UserTaskFlowElement__Group_6_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__9"
+    // InternalTestgeneratorDSL.g:4776:1: rule__DelegateServiceTaskFlowElement__Group__9 : rule__DelegateServiceTaskFlowElement__Group__9__Impl ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4801:1: ( rule__UserTaskFlowElement__Group_6_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:4802:2: rule__UserTaskFlowElement__Group_6_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:4780:1: ( rule__DelegateServiceTaskFlowElement__Group__9__Impl )
+            // InternalTestgeneratorDSL.g:4781:2: rule__DelegateServiceTaskFlowElement__Group__9__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_6_4_1__1__Impl();
+            rule__DelegateServiceTaskFlowElement__Group__9__Impl();
 
             state._fsp--;
 
@@ -15078,35 +14904,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4_1__1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__9"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_6_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:4808:1: rule__UserTaskFlowElement__Group_6_4_1__1__Impl : ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_6_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__9__Impl"
+    // InternalTestgeneratorDSL.g:4787:1: rule__DelegateServiceTaskFlowElement__Group__9__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4812:1: ( ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:4813:1: ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:4791:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:4792:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:4813:1: ( ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:4814:2: ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
+            // InternalTestgeneratorDSL.g:4792:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:4793:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
-            // InternalTestgeneratorDSL.g:4815:2: ( rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
-            // InternalTestgeneratorDSL.g:4815:3: rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
 
             }
 
@@ -15125,26 +14941,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_6_4_1__1__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__9__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__0"
-    // InternalTestgeneratorDSL.g:4824:1: rule__UserTaskFlowElement__Group_7__0 : rule__UserTaskFlowElement__Group_7__0__Impl rule__UserTaskFlowElement__Group_7__1 ;
-    public final void rule__UserTaskFlowElement__Group_7__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__0"
+    // InternalTestgeneratorDSL.g:4803:1: rule__DelegateServiceTaskFlowElement__Group_8__0 : rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4828:1: ( rule__UserTaskFlowElement__Group_7__0__Impl rule__UserTaskFlowElement__Group_7__1 )
-            // InternalTestgeneratorDSL.g:4829:2: rule__UserTaskFlowElement__Group_7__0__Impl rule__UserTaskFlowElement__Group_7__1
+            // InternalTestgeneratorDSL.g:4807:1: ( rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1 )
+            // InternalTestgeneratorDSL.g:4808:2: rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1
             {
-            pushFollow(FOLLOW_29);
-            rule__UserTaskFlowElement__Group_7__0__Impl();
+            pushFollow(FOLLOW_25);
+            rule__DelegateServiceTaskFlowElement__Group_8__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_7__1();
+            rule__DelegateServiceTaskFlowElement__Group_8__1();
 
             state._fsp--;
 
@@ -15163,25 +14979,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__0"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:4836:1: rule__UserTaskFlowElement__Group_7__0__Impl : ( 'and' ) ;
-    public final void rule__UserTaskFlowElement__Group_7__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__0__Impl"
+    // InternalTestgeneratorDSL.g:4815:1: rule__DelegateServiceTaskFlowElement__Group_8__0__Impl : ( 'and' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4840:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:4841:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:4819:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:4820:1: ( 'and' )
             {
-            // InternalTestgeneratorDSL.g:4841:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:4842:2: 'and'
+            // InternalTestgeneratorDSL.g:4820:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:4821:2: 'and'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_7_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_7_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); 
 
             }
 
@@ -15200,26 +15016,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__0__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__1"
-    // InternalTestgeneratorDSL.g:4851:1: rule__UserTaskFlowElement__Group_7__1 : rule__UserTaskFlowElement__Group_7__1__Impl rule__UserTaskFlowElement__Group_7__2 ;
-    public final void rule__UserTaskFlowElement__Group_7__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__1"
+    // InternalTestgeneratorDSL.g:4830:1: rule__DelegateServiceTaskFlowElement__Group_8__1 : rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4855:1: ( rule__UserTaskFlowElement__Group_7__1__Impl rule__UserTaskFlowElement__Group_7__2 )
-            // InternalTestgeneratorDSL.g:4856:2: rule__UserTaskFlowElement__Group_7__1__Impl rule__UserTaskFlowElement__Group_7__2
+            // InternalTestgeneratorDSL.g:4834:1: ( rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2 )
+            // InternalTestgeneratorDSL.g:4835:2: rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2
             {
             pushFollow(FOLLOW_12);
-            rule__UserTaskFlowElement__Group_7__1__Impl();
+            rule__DelegateServiceTaskFlowElement__Group_8__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_7__2();
+            rule__DelegateServiceTaskFlowElement__Group_8__2();
 
             state._fsp--;
 
@@ -15238,25 +15054,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:4863:1: rule__UserTaskFlowElement__Group_7__1__Impl : ( 'label' ) ;
-    public final void rule__UserTaskFlowElement__Group_7__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__1__Impl"
+    // InternalTestgeneratorDSL.g:4842:1: rule__DelegateServiceTaskFlowElement__Group_8__1__Impl : ( 'label' ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4867:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:4868:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:4846:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:4847:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:4868:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:4869:2: 'label'
+            // InternalTestgeneratorDSL.g:4847:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:4848:2: 'label'
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_7_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_7_1()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); 
+            match(input,41,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); 
 
             }
 
@@ -15275,26 +15091,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__1__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__2"
-    // InternalTestgeneratorDSL.g:4878:1: rule__UserTaskFlowElement__Group_7__2 : rule__UserTaskFlowElement__Group_7__2__Impl rule__UserTaskFlowElement__Group_7__3 ;
-    public final void rule__UserTaskFlowElement__Group_7__2() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__2"
+    // InternalTestgeneratorDSL.g:4857:1: rule__DelegateServiceTaskFlowElement__Group_8__2 : rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3 ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4882:1: ( rule__UserTaskFlowElement__Group_7__2__Impl rule__UserTaskFlowElement__Group_7__3 )
-            // InternalTestgeneratorDSL.g:4883:2: rule__UserTaskFlowElement__Group_7__2__Impl rule__UserTaskFlowElement__Group_7__3
+            // InternalTestgeneratorDSL.g:4861:1: ( rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3 )
+            // InternalTestgeneratorDSL.g:4862:2: rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3
             {
             pushFollow(FOLLOW_7);
-            rule__UserTaskFlowElement__Group_7__2__Impl();
+            rule__DelegateServiceTaskFlowElement__Group_8__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_7__3();
+            rule__DelegateServiceTaskFlowElement__Group_8__3();
 
             state._fsp--;
 
@@ -15313,25 +15129,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__2"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__2__Impl"
-    // InternalTestgeneratorDSL.g:4890:1: rule__UserTaskFlowElement__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__UserTaskFlowElement__Group_7__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__2__Impl"
+    // InternalTestgeneratorDSL.g:4869:1: rule__DelegateServiceTaskFlowElement__Group_8__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4894:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:4895:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4873:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4874:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:4895:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:4896:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:4874:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4875:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
 
             }
 
@@ -15350,21 +15166,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__2__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__3"
-    // InternalTestgeneratorDSL.g:4905:1: rule__UserTaskFlowElement__Group_7__3 : rule__UserTaskFlowElement__Group_7__3__Impl ;
-    public final void rule__UserTaskFlowElement__Group_7__3() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__3"
+    // InternalTestgeneratorDSL.g:4884:1: rule__DelegateServiceTaskFlowElement__Group_8__3 : rule__DelegateServiceTaskFlowElement__Group_8__3__Impl ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4909:1: ( rule__UserTaskFlowElement__Group_7__3__Impl )
-            // InternalTestgeneratorDSL.g:4910:2: rule__UserTaskFlowElement__Group_7__3__Impl
+            // InternalTestgeneratorDSL.g:4888:1: ( rule__DelegateServiceTaskFlowElement__Group_8__3__Impl )
+            // InternalTestgeneratorDSL.g:4889:2: rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__Group_7__3__Impl();
+            rule__DelegateServiceTaskFlowElement__Group_8__3__Impl();
 
             state._fsp--;
 
@@ -15383,35 +15199,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__3"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__3"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__Group_7__3__Impl"
-    // InternalTestgeneratorDSL.g:4916:1: rule__UserTaskFlowElement__Group_7__3__Impl : ( ( rule__UserTaskFlowElement__LabelAssignment_7_3 ) ) ;
-    public final void rule__UserTaskFlowElement__Group_7__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__3__Impl"
+    // InternalTestgeneratorDSL.g:4895:1: rule__DelegateServiceTaskFlowElement__Group_8__3__Impl : ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) ) ;
+    public final void rule__DelegateServiceTaskFlowElement__Group_8__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4920:1: ( ( ( rule__UserTaskFlowElement__LabelAssignment_7_3 ) ) )
-            // InternalTestgeneratorDSL.g:4921:1: ( ( rule__UserTaskFlowElement__LabelAssignment_7_3 ) )
+            // InternalTestgeneratorDSL.g:4899:1: ( ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) ) )
+            // InternalTestgeneratorDSL.g:4900:1: ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) )
             {
-            // InternalTestgeneratorDSL.g:4921:1: ( ( rule__UserTaskFlowElement__LabelAssignment_7_3 ) )
-            // InternalTestgeneratorDSL.g:4922:2: ( rule__UserTaskFlowElement__LabelAssignment_7_3 )
+            // InternalTestgeneratorDSL.g:4900:1: ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) )
+            // InternalTestgeneratorDSL.g:4901:2: ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_7_3()); 
-            // InternalTestgeneratorDSL.g:4923:2: ( rule__UserTaskFlowElement__LabelAssignment_7_3 )
-            // InternalTestgeneratorDSL.g:4923:3: rule__UserTaskFlowElement__LabelAssignment_7_3
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); 
+            // InternalTestgeneratorDSL.g:4902:2: ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 )
+            // InternalTestgeneratorDSL.g:4902:3: rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3
             {
             pushFollow(FOLLOW_2);
-            rule__UserTaskFlowElement__LabelAssignment_7_3();
+            rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLabelAssignment_7_3()); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); 
 
             }
 
@@ -15430,26 +15246,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__Group_7__3__Impl"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:4932:1: rule__ManualTaskFlowElement__Group__0 : rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1 ;
-    public final void rule__ManualTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:4911:1: rule__ExternalServiceTaskFlowElement__Group__0 : rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4936:1: ( rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:4937:2: rule__ManualTaskFlowElement__Group__0__Impl rule__ManualTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:4915:1: ( rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:4916:2: rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1
             {
             pushFollow(FOLLOW_4);
-            rule__ManualTaskFlowElement__Group__0__Impl();
+            rule__ExternalServiceTaskFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__1();
+            rule__ExternalServiceTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -15468,25 +15284,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:4944:1: rule__ManualTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__ManualTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:4923:1: rule__ExternalServiceTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4948:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:4949:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:4927:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:4928:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:4949:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:4950:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:4928:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:4929:2: 'FlowElement'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -15505,26 +15321,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:4959:1: rule__ManualTaskFlowElement__Group__1 : rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2 ;
-    public final void rule__ManualTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:4938:1: rule__ExternalServiceTaskFlowElement__Group__1 : rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4963:1: ( rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:4964:2: rule__ManualTaskFlowElement__Group__1__Impl rule__ManualTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:4942:1: ( rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:4943:2: rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__ManualTaskFlowElement__Group__1__Impl();
+            rule__ExternalServiceTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__2();
+            rule__ExternalServiceTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -15543,35 +15359,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:4971:1: rule__ManualTaskFlowElement__Group__1__Impl : ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:4950:1: rule__ExternalServiceTaskFlowElement__Group__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4975:1: ( ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:4976:1: ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:4954:1: ( ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:4955:1: ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:4976:1: ( ( rule__ManualTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:4977:2: ( rule__ManualTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:4955:1: ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:4956:2: ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:4978:2: ( rule__ManualTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:4978:3: rule__ManualTaskFlowElement__NameAssignment_1
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:4957:2: ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:4957:3: rule__ExternalServiceTaskFlowElement__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__NameAssignment_1();
+            rule__ExternalServiceTaskFlowElement__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getNameAssignment_1()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -15590,26 +15406,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:4986:1: rule__ManualTaskFlowElement__Group__2 : rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3 ;
-    public final void rule__ManualTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:4965:1: rule__ExternalServiceTaskFlowElement__Group__2 : rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:4990:1: ( rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:4991:2: rule__ManualTaskFlowElement__Group__2__Impl rule__ManualTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:4969:1: ( rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:4970:2: rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3
             {
-            pushFollow(FOLLOW_30);
-            rule__ManualTaskFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_29);
+            rule__ExternalServiceTaskFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__3();
+            rule__ExternalServiceTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -15628,25 +15444,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__2"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:4998:1: rule__ManualTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ManualTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:4977:1: rule__ExternalServiceTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5002:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:5003:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4981:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:4982:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5003:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:5004:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:4982:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:4983:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -15665,26 +15481,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:5013:1: rule__ManualTaskFlowElement__Group__3 : rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4 ;
-    public final void rule__ManualTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:4992:1: rule__ExternalServiceTaskFlowElement__Group__3 : rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5017:1: ( rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:5018:2: rule__ManualTaskFlowElement__Group__3__Impl rule__ManualTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:4996:1: ( rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:4997:2: rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_26);
-            rule__ManualTaskFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_5);
+            rule__ExternalServiceTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__4();
+            rule__ExternalServiceTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -15703,25 +15519,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__3"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:5025:1: rule__ManualTaskFlowElement__Group__3__Impl : ( 'ManualTask' ) ;
-    public final void rule__ManualTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:5004:1: rule__ExternalServiceTaskFlowElement__Group__3__Impl : ( 'ServiceTask' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5029:1: ( ( 'ManualTask' ) )
-            // InternalTestgeneratorDSL.g:5030:1: ( 'ManualTask' )
+            // InternalTestgeneratorDSL.g:5008:1: ( ( 'ServiceTask' ) )
+            // InternalTestgeneratorDSL.g:5009:1: ( 'ServiceTask' )
             {
-            // InternalTestgeneratorDSL.g:5030:1: ( 'ManualTask' )
-            // InternalTestgeneratorDSL.g:5031:2: 'ManualTask'
+            // InternalTestgeneratorDSL.g:5009:1: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:5010:2: 'ServiceTask'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); 
-            match(input,45,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
+            match(input,44,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
 
             }
 
@@ -15740,26 +15556,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:5040:1: rule__ManualTaskFlowElement__Group__4 : rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5 ;
-    public final void rule__ManualTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:5019:1: rule__ExternalServiceTaskFlowElement__Group__4 : rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5044:1: ( rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:5045:2: rule__ManualTaskFlowElement__Group__4__Impl rule__ManualTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:5023:1: ( rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:5024:2: rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5
             {
-            pushFollow(FOLLOW_26);
-            rule__ManualTaskFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_31);
+            rule__ExternalServiceTaskFlowElement__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__5();
+            rule__ExternalServiceTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -15778,50 +15594,100 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__4"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:5052:1: rule__ManualTaskFlowElement__Group__4__Impl : ( ( rule__ManualTaskFlowElement__Group_4__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:5031:1: rule__ExternalServiceTaskFlowElement__Group__4__Impl : ( 'with' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5056:1: ( ( ( rule__ManualTaskFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:5057:1: ( ( rule__ManualTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:5035:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:5036:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:5057:1: ( ( rule__ManualTaskFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:5058:2: ( rule__ManualTaskFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:5036:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5037:2: 'with'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:5059:2: ( rule__ManualTaskFlowElement__Group_4__0 )?
-            int alt39=2;
-            int LA39_0 = input.LA(1);
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); 
+
+            }
 
-            if ( (LA39_0==28) ) {
-                int LA39_1 = input.LA(2);
 
-                if ( (LA39_1==36) ) {
-                    alt39=1;
-                }
             }
-            switch (alt39) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:5059:3: rule__ManualTaskFlowElement__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_4__0();
 
-                    state._fsp--;
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
 
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__4__Impl"
+
+
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:5046:1: rule__ExternalServiceTaskFlowElement__Group__5 : rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__5() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:5050:1: ( rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6 )
+            // InternalTestgeneratorDSL.g:5051:2: rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6
+            {
+            pushFollow(FOLLOW_12);
+            rule__ExternalServiceTaskFlowElement__Group__5__Impl();
+
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__ExternalServiceTaskFlowElement__Group__6();
+
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4()); 
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__5"
+
+
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:5058:1: rule__ExternalServiceTaskFlowElement__Group__5__Impl : ( 'external' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__5__Impl() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:5062:1: ( ( 'external' ) )
+            // InternalTestgeneratorDSL.g:5063:1: ( 'external' )
+            {
+            // InternalTestgeneratorDSL.g:5063:1: ( 'external' )
+            // InternalTestgeneratorDSL.g:5064:2: 'external'
+            {
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); 
+            match(input,46,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); 
 
             }
 
@@ -15840,26 +15706,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:5067:1: rule__ManualTaskFlowElement__Group__5 : rule__ManualTaskFlowElement__Group__5__Impl rule__ManualTaskFlowElement__Group__6 ;
-    public final void rule__ManualTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__6"
+    // InternalTestgeneratorDSL.g:5073:1: rule__ExternalServiceTaskFlowElement__Group__6 : rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5071:1: ( rule__ManualTaskFlowElement__Group__5__Impl rule__ManualTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:5072:2: rule__ManualTaskFlowElement__Group__5__Impl rule__ManualTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:5077:1: ( rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7 )
+            // InternalTestgeneratorDSL.g:5078:2: rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7
             {
-            pushFollow(FOLLOW_26);
-            rule__ManualTaskFlowElement__Group__5__Impl();
+            pushFollow(FOLLOW_4);
+            rule__ExternalServiceTaskFlowElement__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__6();
+            rule__ExternalServiceTaskFlowElement__Group__7();
 
             state._fsp--;
 
@@ -15878,50 +15744,110 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__5"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__6"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:5079:1: rule__ManualTaskFlowElement__Group__5__Impl : ( ( rule__ManualTaskFlowElement__Group_5__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:5085:1: rule__ExternalServiceTaskFlowElement__Group__6__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5083:1: ( ( ( rule__ManualTaskFlowElement__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:5084:1: ( ( rule__ManualTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:5089:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5090:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5084:1: ( ( rule__ManualTaskFlowElement__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:5085:2: ( rule__ManualTaskFlowElement__Group_5__0 )?
+            // InternalTestgeneratorDSL.g:5090:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5091:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:5086:2: ( rule__ManualTaskFlowElement__Group_5__0 )?
-            int alt40=2;
-            int LA40_0 = input.LA(1);
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
+
+            }
 
-            if ( (LA40_0==28) ) {
-                int LA40_1 = input.LA(2);
 
-                if ( (LA40_1==41) ) {
-                    alt40=1;
-                }
             }
-            switch (alt40) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:5086:3: rule__ManualTaskFlowElement__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_5__0();
 
-                    state._fsp--;
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
 
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__6__Impl"
+
+
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__7"
+    // InternalTestgeneratorDSL.g:5100:1: rule__ExternalServiceTaskFlowElement__Group__7 : rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__7() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:5104:1: ( rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8 )
+            // InternalTestgeneratorDSL.g:5105:2: rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8
+            {
+            pushFollow(FOLLOW_24);
+            rule__ExternalServiceTaskFlowElement__Group__7__Impl();
+
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__ExternalServiceTaskFlowElement__Group__8();
+
+            state._fsp--;
+
+
+            }
+
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__7"
+
+
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:5112:1: rule__ExternalServiceTaskFlowElement__Group__7__Impl : ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__7__Impl() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:5116:1: ( ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) ) )
+            // InternalTestgeneratorDSL.g:5117:1: ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) )
+            {
+            // InternalTestgeneratorDSL.g:5117:1: ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:5118:2: ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 )
+            {
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); 
+            // InternalTestgeneratorDSL.g:5119:2: ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 )
+            // InternalTestgeneratorDSL.g:5119:3: rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7
+            {
+            pushFollow(FOLLOW_2);
+            rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7();
+
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); 
 
             }
 
@@ -15940,26 +15866,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__7__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:5094:1: rule__ManualTaskFlowElement__Group__6 : rule__ManualTaskFlowElement__Group__6__Impl rule__ManualTaskFlowElement__Group__7 ;
-    public final void rule__ManualTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__8"
+    // InternalTestgeneratorDSL.g:5127:1: rule__ExternalServiceTaskFlowElement__Group__8 : rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5098:1: ( rule__ManualTaskFlowElement__Group__6__Impl rule__ManualTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:5099:2: rule__ManualTaskFlowElement__Group__6__Impl rule__ManualTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:5131:1: ( rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9 )
+            // InternalTestgeneratorDSL.g:5132:2: rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9
             {
-            pushFollow(FOLLOW_26);
-            rule__ManualTaskFlowElement__Group__6__Impl();
+            pushFollow(FOLLOW_24);
+            rule__ExternalServiceTaskFlowElement__Group__8__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__7();
+            rule__ExternalServiceTaskFlowElement__Group__9();
 
             state._fsp--;
 
@@ -15978,36 +15904,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__6"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__8"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:5106:1: rule__ManualTaskFlowElement__Group__6__Impl : ( ( rule__ManualTaskFlowElement__Group_6__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:5139:1: rule__ExternalServiceTaskFlowElement__Group__8__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5110:1: ( ( ( rule__ManualTaskFlowElement__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:5111:1: ( ( rule__ManualTaskFlowElement__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:5143:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? ) )
+            // InternalTestgeneratorDSL.g:5144:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? )
             {
-            // InternalTestgeneratorDSL.g:5111:1: ( ( rule__ManualTaskFlowElement__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:5112:2: ( rule__ManualTaskFlowElement__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:5144:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? )
+            // InternalTestgeneratorDSL.g:5145:2: ( rule__ExternalServiceTaskFlowElement__Group_8__0 )?
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:5113:2: ( rule__ManualTaskFlowElement__Group_6__0 )?
-            int alt41=2;
-            int LA41_0 = input.LA(1);
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); 
+            // InternalTestgeneratorDSL.g:5146:2: ( rule__ExternalServiceTaskFlowElement__Group_8__0 )?
+            int alt33=2;
+            int LA33_0 = input.LA(1);
 
-            if ( (LA41_0==28) ) {
-                alt41=1;
+            if ( (LA33_0==29) ) {
+                alt33=1;
             }
-            switch (alt41) {
+            switch (alt33) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5113:3: rule__ManualTaskFlowElement__Group_6__0
+                    // InternalTestgeneratorDSL.g:5146:3: rule__ExternalServiceTaskFlowElement__Group_8__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_6__0();
+                    rule__ExternalServiceTaskFlowElement__Group_8__0();
 
                     state._fsp--;
 
@@ -16017,7 +15943,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); 
 
             }
 
@@ -16036,26 +15962,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:5121:1: rule__ManualTaskFlowElement__Group__7 : rule__ManualTaskFlowElement__Group__7__Impl rule__ManualTaskFlowElement__Group__8 ;
-    public final void rule__ManualTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__9"
+    // InternalTestgeneratorDSL.g:5154:1: rule__ExternalServiceTaskFlowElement__Group__9 : rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5125:1: ( rule__ManualTaskFlowElement__Group__7__Impl rule__ManualTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:5126:2: rule__ManualTaskFlowElement__Group__7__Impl rule__ManualTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:5158:1: ( rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10 )
+            // InternalTestgeneratorDSL.g:5159:2: rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10
             {
-            pushFollow(FOLLOW_26);
-            rule__ManualTaskFlowElement__Group__7__Impl();
+            pushFollow(FOLLOW_24);
+            rule__ExternalServiceTaskFlowElement__Group__9__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__8();
+            rule__ExternalServiceTaskFlowElement__Group__10();
 
             state._fsp--;
 
@@ -16074,36 +16000,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__7"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__9"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:5133:1: rule__ManualTaskFlowElement__Group__7__Impl : ( ( rule__ManualTaskFlowElement__Group_7__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__9__Impl"
+    // InternalTestgeneratorDSL.g:5166:1: rule__ExternalServiceTaskFlowElement__Group__9__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5137:1: ( ( ( rule__ManualTaskFlowElement__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:5138:1: ( ( rule__ManualTaskFlowElement__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:5170:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? ) )
+            // InternalTestgeneratorDSL.g:5171:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? )
             {
-            // InternalTestgeneratorDSL.g:5138:1: ( ( rule__ManualTaskFlowElement__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:5139:2: ( rule__ManualTaskFlowElement__Group_7__0 )?
+            // InternalTestgeneratorDSL.g:5171:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? )
+            // InternalTestgeneratorDSL.g:5172:2: ( rule__ExternalServiceTaskFlowElement__Group_9__0 )?
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:5140:2: ( rule__ManualTaskFlowElement__Group_7__0 )?
-            int alt42=2;
-            int LA42_0 = input.LA(1);
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); 
+            // InternalTestgeneratorDSL.g:5173:2: ( rule__ExternalServiceTaskFlowElement__Group_9__0 )?
+            int alt34=2;
+            int LA34_0 = input.LA(1);
 
-            if ( (LA42_0==43) ) {
-                alt42=1;
+            if ( (LA34_0==40) ) {
+                alt34=1;
             }
-            switch (alt42) {
+            switch (alt34) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5140:3: rule__ManualTaskFlowElement__Group_7__0
+                    // InternalTestgeneratorDSL.g:5173:3: rule__ExternalServiceTaskFlowElement__Group_9__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_7__0();
+                    rule__ExternalServiceTaskFlowElement__Group_9__0();
 
                     state._fsp--;
 
@@ -16113,7 +16039,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_7()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); 
 
             }
 
@@ -16132,21 +16058,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__9__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:5148:1: rule__ManualTaskFlowElement__Group__8 : rule__ManualTaskFlowElement__Group__8__Impl ;
-    public final void rule__ManualTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__10"
+    // InternalTestgeneratorDSL.g:5181:1: rule__ExternalServiceTaskFlowElement__Group__10 : rule__ExternalServiceTaskFlowElement__Group__10__Impl ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5152:1: ( rule__ManualTaskFlowElement__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:5153:2: rule__ManualTaskFlowElement__Group__8__Impl
+            // InternalTestgeneratorDSL.g:5185:1: ( rule__ExternalServiceTaskFlowElement__Group__10__Impl )
+            // InternalTestgeneratorDSL.g:5186:2: rule__ExternalServiceTaskFlowElement__Group__10__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group__8__Impl();
+            rule__ExternalServiceTaskFlowElement__Group__10__Impl();
 
             state._fsp--;
 
@@ -16165,25 +16091,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__8"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__10"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:5159:1: rule__ManualTaskFlowElement__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__ManualTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__10__Impl"
+    // InternalTestgeneratorDSL.g:5192:1: rule__ExternalServiceTaskFlowElement__Group__10__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group__10__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5163:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:5164:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:5196:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:5197:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:5164:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:5165:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:5197:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:5198:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_10()); 
             match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_10()); 
 
             }
 
@@ -16202,26 +16128,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group__8__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__10__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:5175:1: rule__ManualTaskFlowElement__Group_4__0 : rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1 ;
-    public final void rule__ManualTaskFlowElement__Group_4__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__0"
+    // InternalTestgeneratorDSL.g:5208:1: rule__ExternalServiceTaskFlowElement__Group_8__0 : rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5179:1: ( rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:5180:2: rule__ManualTaskFlowElement__Group_4__0__Impl rule__ManualTaskFlowElement__Group_4__1
+            // InternalTestgeneratorDSL.g:5212:1: ( rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1 )
+            // InternalTestgeneratorDSL.g:5213:2: rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1
             {
-            pushFollow(FOLLOW_19);
-            rule__ManualTaskFlowElement__Group_4__0__Impl();
+            pushFollow(FOLLOW_32);
+            rule__ExternalServiceTaskFlowElement__Group_8__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__1();
+            rule__ExternalServiceTaskFlowElement__Group_8__1();
 
             state._fsp--;
 
@@ -16240,25 +16166,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:5187:1: rule__ManualTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__0__Impl"
+    // InternalTestgeneratorDSL.g:5220:1: rule__ExternalServiceTaskFlowElement__Group_8__0__Impl : ( 'with' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5191:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:5192:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5224:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:5225:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:5192:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:5193:2: 'with'
+            // InternalTestgeneratorDSL.g:5225:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5226:2: 'with'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_4_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); 
 
             }
 
@@ -16277,26 +16203,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__0__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:5202:1: rule__ManualTaskFlowElement__Group_4__1 : rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2 ;
-    public final void rule__ManualTaskFlowElement__Group_4__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__1"
+    // InternalTestgeneratorDSL.g:5235:1: rule__ExternalServiceTaskFlowElement__Group_8__1 : rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5206:1: ( rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:5207:2: rule__ManualTaskFlowElement__Group_4__1__Impl rule__ManualTaskFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:5239:1: ( rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2 )
+            // InternalTestgeneratorDSL.g:5240:2: rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2
             {
-            pushFollow(FOLLOW_20);
-            rule__ManualTaskFlowElement__Group_4__1__Impl();
+            pushFollow(FOLLOW_33);
+            rule__ExternalServiceTaskFlowElement__Group_8__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__2();
+            rule__ExternalServiceTaskFlowElement__Group_8__2();
 
             state._fsp--;
 
@@ -16315,25 +16241,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:5214:1: rule__ManualTaskFlowElement__Group_4__1__Impl : ( 'hardcoded' ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__1__Impl"
+    // InternalTestgeneratorDSL.g:5247:1: rule__ExternalServiceTaskFlowElement__Group_8__1__Impl : ( 'hardcoded' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5218:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:5219:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:5251:1: ( ( 'hardcoded' ) )
+            // InternalTestgeneratorDSL.g:5252:1: ( 'hardcoded' )
             {
-            // InternalTestgeneratorDSL.g:5219:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:5220:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:5252:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:5253:2: 'hardcoded'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); 
+            match(input,47,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); 
 
             }
 
@@ -16352,26 +16278,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__1__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:5229:1: rule__ManualTaskFlowElement__Group_4__2 : rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3 ;
-    public final void rule__ManualTaskFlowElement__Group_4__2() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__2"
+    // InternalTestgeneratorDSL.g:5262:1: rule__ExternalServiceTaskFlowElement__Group_8__2 : rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5233:1: ( rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:5234:2: rule__ManualTaskFlowElement__Group_4__2__Impl rule__ManualTaskFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:5266:1: ( rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3 )
+            // InternalTestgeneratorDSL.g:5267:2: rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3
             {
             pushFollow(FOLLOW_12);
-            rule__ManualTaskFlowElement__Group_4__2__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__3();
+            rule__ExternalServiceTaskFlowElement__Group_8__3();
 
             state._fsp--;
 
@@ -16390,25 +16316,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__2"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:5241:1: rule__ManualTaskFlowElement__Group_4__2__Impl : ( 'inputs' ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__2__Impl"
+    // InternalTestgeneratorDSL.g:5274:1: rule__ExternalServiceTaskFlowElement__Group_8__2__Impl : ( 'inputs' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5245:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:5246:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:5278:1: ( ( 'inputs' ) )
+            // InternalTestgeneratorDSL.g:5279:1: ( 'inputs' )
             {
-            // InternalTestgeneratorDSL.g:5246:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:5247:2: 'inputs'
+            // InternalTestgeneratorDSL.g:5279:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:5280:2: 'inputs'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputsKeyword_4_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputsKeyword_4_2()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); 
+            match(input,48,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); 
 
             }
 
@@ -16427,26 +16353,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__2__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:5256:1: rule__ManualTaskFlowElement__Group_4__3 : rule__ManualTaskFlowElement__Group_4__3__Impl rule__ManualTaskFlowElement__Group_4__4 ;
-    public final void rule__ManualTaskFlowElement__Group_4__3() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__3"
+    // InternalTestgeneratorDSL.g:5289:1: rule__ExternalServiceTaskFlowElement__Group_8__3 : rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5260:1: ( rule__ManualTaskFlowElement__Group_4__3__Impl rule__ManualTaskFlowElement__Group_4__4 )
-            // InternalTestgeneratorDSL.g:5261:2: rule__ManualTaskFlowElement__Group_4__3__Impl rule__ManualTaskFlowElement__Group_4__4
+            // InternalTestgeneratorDSL.g:5293:1: ( rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4 )
+            // InternalTestgeneratorDSL.g:5294:2: rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4
             {
             pushFollow(FOLLOW_13);
-            rule__ManualTaskFlowElement__Group_4__3__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__4();
+            rule__ExternalServiceTaskFlowElement__Group_8__4();
 
             state._fsp--;
 
@@ -16465,25 +16391,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__3"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:5268:1: rule__ManualTaskFlowElement__Group_4__3__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__3__Impl"
+    // InternalTestgeneratorDSL.g:5301:1: rule__ExternalServiceTaskFlowElement__Group_8__3__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5272:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:5273:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5305:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5306:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5273:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:5274:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:5306:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5307:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); 
 
             }
 
@@ -16502,26 +16428,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__3__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__4"
-    // InternalTestgeneratorDSL.g:5283:1: rule__ManualTaskFlowElement__Group_4__4 : rule__ManualTaskFlowElement__Group_4__4__Impl rule__ManualTaskFlowElement__Group_4__5 ;
-    public final void rule__ManualTaskFlowElement__Group_4__4() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__4"
+    // InternalTestgeneratorDSL.g:5316:1: rule__ExternalServiceTaskFlowElement__Group_8__4 : rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5287:1: ( rule__ManualTaskFlowElement__Group_4__4__Impl rule__ManualTaskFlowElement__Group_4__5 )
-            // InternalTestgeneratorDSL.g:5288:2: rule__ManualTaskFlowElement__Group_4__4__Impl rule__ManualTaskFlowElement__Group_4__5
+            // InternalTestgeneratorDSL.g:5320:1: ( rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5 )
+            // InternalTestgeneratorDSL.g:5321:2: rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_4__4__Impl();
+            pushFollow(FOLLOW_20);
+            rule__ExternalServiceTaskFlowElement__Group_8__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__5();
+            rule__ExternalServiceTaskFlowElement__Group_8__5();
 
             state._fsp--;
 
@@ -16540,25 +16466,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__4"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__4"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__4__Impl"
-    // InternalTestgeneratorDSL.g:5295:1: rule__ManualTaskFlowElement__Group_4__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__4__Impl"
+    // InternalTestgeneratorDSL.g:5328:1: rule__ExternalServiceTaskFlowElement__Group_8__4__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5299:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:5300:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:5332:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:5333:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:5300:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:5301:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:5333:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:5334:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); 
             match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); 
 
             }
 
@@ -16577,26 +16503,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__4__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__4__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__5"
-    // InternalTestgeneratorDSL.g:5310:1: rule__ManualTaskFlowElement__Group_4__5 : rule__ManualTaskFlowElement__Group_4__5__Impl rule__ManualTaskFlowElement__Group_4__6 ;
-    public final void rule__ManualTaskFlowElement__Group_4__5() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__5"
+    // InternalTestgeneratorDSL.g:5343:1: rule__ExternalServiceTaskFlowElement__Group_8__5 : rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5314:1: ( rule__ManualTaskFlowElement__Group_4__5__Impl rule__ManualTaskFlowElement__Group_4__6 )
-            // InternalTestgeneratorDSL.g:5315:2: rule__ManualTaskFlowElement__Group_4__5__Impl rule__ManualTaskFlowElement__Group_4__6
+            // InternalTestgeneratorDSL.g:5347:1: ( rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6 )
+            // InternalTestgeneratorDSL.g:5348:2: rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_4__5__Impl();
+            pushFollow(FOLLOW_20);
+            rule__ExternalServiceTaskFlowElement__Group_8__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__6();
+            rule__ExternalServiceTaskFlowElement__Group_8__6();
 
             state._fsp--;
 
@@ -16615,36 +16541,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__5"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__5"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__5__Impl"
-    // InternalTestgeneratorDSL.g:5322:1: rule__ManualTaskFlowElement__Group_4__5__Impl : ( ( rule__ManualTaskFlowElement__Group_4_5__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__5__Impl"
+    // InternalTestgeneratorDSL.g:5355:1: rule__ExternalServiceTaskFlowElement__Group_8__5__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5326:1: ( ( ( rule__ManualTaskFlowElement__Group_4_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:5327:1: ( ( rule__ManualTaskFlowElement__Group_4_5__0 )? )
+            // InternalTestgeneratorDSL.g:5359:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:5360:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? )
             {
-            // InternalTestgeneratorDSL.g:5327:1: ( ( rule__ManualTaskFlowElement__Group_4_5__0 )? )
-            // InternalTestgeneratorDSL.g:5328:2: ( rule__ManualTaskFlowElement__Group_4_5__0 )?
+            // InternalTestgeneratorDSL.g:5360:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? )
+            // InternalTestgeneratorDSL.g:5361:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )?
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5()); 
-            // InternalTestgeneratorDSL.g:5329:2: ( rule__ManualTaskFlowElement__Group_4_5__0 )?
-            int alt43=2;
-            int LA43_0 = input.LA(1);
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); 
+            // InternalTestgeneratorDSL.g:5362:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )?
+            int alt35=2;
+            int LA35_0 = input.LA(1);
 
-            if ( (LA43_0==RULE_ID) ) {
-                alt43=1;
+            if ( (LA35_0==RULE_ID) ) {
+                alt35=1;
             }
-            switch (alt43) {
+            switch (alt35) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5329:3: rule__ManualTaskFlowElement__Group_4_5__0
+                    // InternalTestgeneratorDSL.g:5362:3: rule__ExternalServiceTaskFlowElement__Group_8_5__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_4_5__0();
+                    rule__ExternalServiceTaskFlowElement__Group_8_5__0();
 
                     state._fsp--;
 
@@ -16654,7 +16580,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); 
 
             }
 
@@ -16673,21 +16599,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__5__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__5__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__6"
-    // InternalTestgeneratorDSL.g:5337:1: rule__ManualTaskFlowElement__Group_4__6 : rule__ManualTaskFlowElement__Group_4__6__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_4__6() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__6"
+    // InternalTestgeneratorDSL.g:5370:1: rule__ExternalServiceTaskFlowElement__Group_8__6 : rule__ExternalServiceTaskFlowElement__Group_8__6__Impl ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5341:1: ( rule__ManualTaskFlowElement__Group_4__6__Impl )
-            // InternalTestgeneratorDSL.g:5342:2: rule__ManualTaskFlowElement__Group_4__6__Impl
+            // InternalTestgeneratorDSL.g:5374:1: ( rule__ExternalServiceTaskFlowElement__Group_8__6__Impl )
+            // InternalTestgeneratorDSL.g:5375:2: rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4__6__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8__6__Impl();
 
             state._fsp--;
 
@@ -16706,25 +16632,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__6"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__6"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4__6__Impl"
-    // InternalTestgeneratorDSL.g:5348:1: rule__ManualTaskFlowElement__Group_4__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ManualTaskFlowElement__Group_4__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__6__Impl"
+    // InternalTestgeneratorDSL.g:5381:1: rule__ExternalServiceTaskFlowElement__Group_8__6__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5352:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:5353:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:5385:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:5386:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:5353:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:5354:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:5386:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:5387:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); 
             match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); 
 
             }
 
@@ -16743,26 +16669,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4__6__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__6__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5__0"
-    // InternalTestgeneratorDSL.g:5364:1: rule__ManualTaskFlowElement__Group_4_5__0 : rule__ManualTaskFlowElement__Group_4_5__0__Impl rule__ManualTaskFlowElement__Group_4_5__1 ;
-    public final void rule__ManualTaskFlowElement__Group_4_5__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__0"
+    // InternalTestgeneratorDSL.g:5397:1: rule__ExternalServiceTaskFlowElement__Group_8_5__0 : rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5368:1: ( rule__ManualTaskFlowElement__Group_4_5__0__Impl rule__ManualTaskFlowElement__Group_4_5__1 )
-            // InternalTestgeneratorDSL.g:5369:2: rule__ManualTaskFlowElement__Group_4_5__0__Impl rule__ManualTaskFlowElement__Group_4_5__1
+            // InternalTestgeneratorDSL.g:5401:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1 )
+            // InternalTestgeneratorDSL.g:5402:2: rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1
             {
             pushFollow(FOLLOW_15);
-            rule__ManualTaskFlowElement__Group_4_5__0__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4_5__1();
+            rule__ExternalServiceTaskFlowElement__Group_8_5__1();
 
             state._fsp--;
 
@@ -16781,35 +16707,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5__0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5__0__Impl"
-    // InternalTestgeneratorDSL.g:5376:1: rule__ManualTaskFlowElement__Group_4_5__0__Impl : ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_4_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl"
+    // InternalTestgeneratorDSL.g:5409:1: rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl : ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5380:1: ( ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:5381:1: ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
+            // InternalTestgeneratorDSL.g:5413:1: ( ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) ) )
+            // InternalTestgeneratorDSL.g:5414:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) )
             {
-            // InternalTestgeneratorDSL.g:5381:1: ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            // InternalTestgeneratorDSL.g:5382:2: ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
+            // InternalTestgeneratorDSL.g:5414:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) )
+            // InternalTestgeneratorDSL.g:5415:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
-            // InternalTestgeneratorDSL.g:5383:2: ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
-            // InternalTestgeneratorDSL.g:5383:3: rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); 
+            // InternalTestgeneratorDSL.g:5416:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 )
+            // InternalTestgeneratorDSL.g:5416:3: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0();
+            rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); 
 
             }
 
@@ -16828,21 +16754,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5__0__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5__1"
-    // InternalTestgeneratorDSL.g:5391:1: rule__ManualTaskFlowElement__Group_4_5__1 : rule__ManualTaskFlowElement__Group_4_5__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_4_5__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__1"
+    // InternalTestgeneratorDSL.g:5424:1: rule__ExternalServiceTaskFlowElement__Group_8_5__1 : rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5395:1: ( rule__ManualTaskFlowElement__Group_4_5__1__Impl )
-            // InternalTestgeneratorDSL.g:5396:2: rule__ManualTaskFlowElement__Group_4_5__1__Impl
+            // InternalTestgeneratorDSL.g:5428:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl )
+            // InternalTestgeneratorDSL.g:5429:2: rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4_5__1__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl();
 
             state._fsp--;
 
@@ -16861,40 +16787,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5__1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5__1__Impl"
-    // InternalTestgeneratorDSL.g:5402:1: rule__ManualTaskFlowElement__Group_4_5__1__Impl : ( ( rule__ManualTaskFlowElement__Group_4_5_1__0 )* ) ;
-    public final void rule__ManualTaskFlowElement__Group_4_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl"
+    // InternalTestgeneratorDSL.g:5435:1: rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5406:1: ( ( ( rule__ManualTaskFlowElement__Group_4_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:5407:1: ( ( rule__ManualTaskFlowElement__Group_4_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:5439:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:5440:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:5407:1: ( ( rule__ManualTaskFlowElement__Group_4_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:5408:2: ( rule__ManualTaskFlowElement__Group_4_5_1__0 )*
+            // InternalTestgeneratorDSL.g:5440:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:5441:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )*
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5_1()); 
-            // InternalTestgeneratorDSL.g:5409:2: ( rule__ManualTaskFlowElement__Group_4_5_1__0 )*
-            loop44:
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); 
+            // InternalTestgeneratorDSL.g:5442:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )*
+            loop36:
             do {
-                int alt44=2;
-                int LA44_0 = input.LA(1);
+                int alt36=2;
+                int LA36_0 = input.LA(1);
 
-                if ( (LA44_0==RULE_SEPARATOR) ) {
-                    alt44=1;
+                if ( (LA36_0==RULE_SEPARATOR) ) {
+                    alt36=1;
                 }
 
 
-                switch (alt44) {
+                switch (alt36) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:5409:3: rule__ManualTaskFlowElement__Group_4_5_1__0
+            	    // InternalTestgeneratorDSL.g:5442:3: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__ManualTaskFlowElement__Group_4_5_1__0();
+            	    rule__ExternalServiceTaskFlowElement__Group_8_5_1__0();
 
             	    state._fsp--;
 
@@ -16903,11 +16829,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop44;
+            	    break loop36;
                 }
             } while (true);
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_4_5_1()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); 
 
             }
 
@@ -16926,26 +16852,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5__1__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5_1__0"
-    // InternalTestgeneratorDSL.g:5418:1: rule__ManualTaskFlowElement__Group_4_5_1__0 : rule__ManualTaskFlowElement__Group_4_5_1__0__Impl rule__ManualTaskFlowElement__Group_4_5_1__1 ;
-    public final void rule__ManualTaskFlowElement__Group_4_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0"
+    // InternalTestgeneratorDSL.g:5451:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 : rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5422:1: ( rule__ManualTaskFlowElement__Group_4_5_1__0__Impl rule__ManualTaskFlowElement__Group_4_5_1__1 )
-            // InternalTestgeneratorDSL.g:5423:2: rule__ManualTaskFlowElement__Group_4_5_1__0__Impl rule__ManualTaskFlowElement__Group_4_5_1__1
+            // InternalTestgeneratorDSL.g:5455:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 )
+            // InternalTestgeneratorDSL.g:5456:2: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
             {
             pushFollow(FOLLOW_4);
-            rule__ManualTaskFlowElement__Group_4_5_1__0__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4_5_1__1();
+            rule__ExternalServiceTaskFlowElement__Group_8_5_1__1();
 
             state._fsp--;
 
@@ -16964,25 +16890,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5_1__0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:5430:1: rule__ManualTaskFlowElement__Group_4_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ManualTaskFlowElement__Group_4_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl"
+    // InternalTestgeneratorDSL.g:5463:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5434:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:5435:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:5467:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:5468:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:5435:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:5436:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:5468:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:5469:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); 
 
             }
 
@@ -17001,21 +16927,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5_1__0__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5_1__1"
-    // InternalTestgeneratorDSL.g:5445:1: rule__ManualTaskFlowElement__Group_4_5_1__1 : rule__ManualTaskFlowElement__Group_4_5_1__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_4_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1"
+    // InternalTestgeneratorDSL.g:5478:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 : rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5449:1: ( rule__ManualTaskFlowElement__Group_4_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:5450:2: rule__ManualTaskFlowElement__Group_4_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:5482:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl )
+            // InternalTestgeneratorDSL.g:5483:2: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_4_5_1__1__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl();
 
             state._fsp--;
 
@@ -17034,35 +16960,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5_1__1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_4_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:5456:1: rule__ManualTaskFlowElement__Group_4_5_1__1__Impl : ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_4_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl"
+    // InternalTestgeneratorDSL.g:5489:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5460:1: ( ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:5461:1: ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:5493:1: ( ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:5494:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:5461:1: ( ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:5462:2: ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
+            // InternalTestgeneratorDSL.g:5494:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:5495:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
-            // InternalTestgeneratorDSL.g:5463:2: ( rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
-            // InternalTestgeneratorDSL.g:5463:3: rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); 
+            // InternalTestgeneratorDSL.g:5496:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 )
+            // InternalTestgeneratorDSL.g:5496:3: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1();
+            rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); 
 
             }
 
@@ -17081,26 +17007,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_4_5_1__1__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__0"
-    // InternalTestgeneratorDSL.g:5472:1: rule__ManualTaskFlowElement__Group_5__0 : rule__ManualTaskFlowElement__Group_5__0__Impl rule__ManualTaskFlowElement__Group_5__1 ;
-    public final void rule__ManualTaskFlowElement__Group_5__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__0"
+    // InternalTestgeneratorDSL.g:5505:1: rule__ExternalServiceTaskFlowElement__Group_9__0 : rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5476:1: ( rule__ManualTaskFlowElement__Group_5__0__Impl rule__ManualTaskFlowElement__Group_5__1 )
-            // InternalTestgeneratorDSL.g:5477:2: rule__ManualTaskFlowElement__Group_5__0__Impl rule__ManualTaskFlowElement__Group_5__1
+            // InternalTestgeneratorDSL.g:5509:1: ( rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1 )
+            // InternalTestgeneratorDSL.g:5510:2: rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1
             {
-            pushFollow(FOLLOW_27);
-            rule__ManualTaskFlowElement__Group_5__0__Impl();
+            pushFollow(FOLLOW_25);
+            rule__ExternalServiceTaskFlowElement__Group_9__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__1();
+            rule__ExternalServiceTaskFlowElement__Group_9__1();
 
             state._fsp--;
 
@@ -17119,25 +17045,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:5484:1: rule__ManualTaskFlowElement__Group_5__0__Impl : ( 'with' ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__0__Impl"
+    // InternalTestgeneratorDSL.g:5517:1: rule__ExternalServiceTaskFlowElement__Group_9__0__Impl : ( 'and' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5488:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:5489:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5521:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:5522:1: ( 'and' )
             {
-            // InternalTestgeneratorDSL.g:5489:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:5490:2: 'with'
+            // InternalTestgeneratorDSL.g:5522:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:5523:2: 'and'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_5_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_5_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_9_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_9_0()); 
 
             }
 
@@ -17156,26 +17082,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__0__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__1"
-    // InternalTestgeneratorDSL.g:5499:1: rule__ManualTaskFlowElement__Group_5__1 : rule__ManualTaskFlowElement__Group_5__1__Impl rule__ManualTaskFlowElement__Group_5__2 ;
-    public final void rule__ManualTaskFlowElement__Group_5__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__1"
+    // InternalTestgeneratorDSL.g:5532:1: rule__ExternalServiceTaskFlowElement__Group_9__1 : rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5503:1: ( rule__ManualTaskFlowElement__Group_5__1__Impl rule__ManualTaskFlowElement__Group_5__2 )
-            // InternalTestgeneratorDSL.g:5504:2: rule__ManualTaskFlowElement__Group_5__1__Impl rule__ManualTaskFlowElement__Group_5__2
+            // InternalTestgeneratorDSL.g:5536:1: ( rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2 )
+            // InternalTestgeneratorDSL.g:5537:2: rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2
             {
             pushFollow(FOLLOW_12);
-            rule__ManualTaskFlowElement__Group_5__1__Impl();
+            rule__ExternalServiceTaskFlowElement__Group_9__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__2();
+            rule__ExternalServiceTaskFlowElement__Group_9__2();
 
             state._fsp--;
 
@@ -17194,25 +17120,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:5511:1: rule__ManualTaskFlowElement__Group_5__1__Impl : ( 'inputVariables' ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__1__Impl"
+    // InternalTestgeneratorDSL.g:5544:1: rule__ExternalServiceTaskFlowElement__Group_9__1__Impl : ( 'label' ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5515:1: ( ( 'inputVariables' ) )
-            // InternalTestgeneratorDSL.g:5516:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:5548:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:5549:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:5516:1: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:5517:2: 'inputVariables'
+            // InternalTestgeneratorDSL.g:5549:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:5550:2: 'label'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_9_1()); 
             match(input,41,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_9_1()); 
 
             }
 
@@ -17231,26 +17157,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__1__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__2"
-    // InternalTestgeneratorDSL.g:5526:1: rule__ManualTaskFlowElement__Group_5__2 : rule__ManualTaskFlowElement__Group_5__2__Impl rule__ManualTaskFlowElement__Group_5__3 ;
-    public final void rule__ManualTaskFlowElement__Group_5__2() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__2"
+    // InternalTestgeneratorDSL.g:5559:1: rule__ExternalServiceTaskFlowElement__Group_9__2 : rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3 ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5530:1: ( rule__ManualTaskFlowElement__Group_5__2__Impl rule__ManualTaskFlowElement__Group_5__3 )
-            // InternalTestgeneratorDSL.g:5531:2: rule__ManualTaskFlowElement__Group_5__2__Impl rule__ManualTaskFlowElement__Group_5__3
+            // InternalTestgeneratorDSL.g:5563:1: ( rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3 )
+            // InternalTestgeneratorDSL.g:5564:2: rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3
             {
-            pushFollow(FOLLOW_13);
-            rule__ManualTaskFlowElement__Group_5__2__Impl();
+            pushFollow(FOLLOW_7);
+            rule__ExternalServiceTaskFlowElement__Group_9__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__3();
+            rule__ExternalServiceTaskFlowElement__Group_9__3();
 
             state._fsp--;
 
@@ -17269,25 +17195,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__2"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__2__Impl"
-    // InternalTestgeneratorDSL.g:5538:1: rule__ManualTaskFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__2__Impl"
+    // InternalTestgeneratorDSL.g:5571:1: rule__ExternalServiceTaskFlowElement__Group_9__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5542:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:5543:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5575:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5576:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5543:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:5544:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:5576:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5577:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); 
 
             }
 
@@ -17306,26 +17232,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__2__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__3"
-    // InternalTestgeneratorDSL.g:5553:1: rule__ManualTaskFlowElement__Group_5__3 : rule__ManualTaskFlowElement__Group_5__3__Impl rule__ManualTaskFlowElement__Group_5__4 ;
-    public final void rule__ManualTaskFlowElement__Group_5__3() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__3"
+    // InternalTestgeneratorDSL.g:5586:1: rule__ExternalServiceTaskFlowElement__Group_9__3 : rule__ExternalServiceTaskFlowElement__Group_9__3__Impl ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5557:1: ( rule__ManualTaskFlowElement__Group_5__3__Impl rule__ManualTaskFlowElement__Group_5__4 )
-            // InternalTestgeneratorDSL.g:5558:2: rule__ManualTaskFlowElement__Group_5__3__Impl rule__ManualTaskFlowElement__Group_5__4
+            // InternalTestgeneratorDSL.g:5590:1: ( rule__ExternalServiceTaskFlowElement__Group_9__3__Impl )
+            // InternalTestgeneratorDSL.g:5591:2: rule__ExternalServiceTaskFlowElement__Group_9__3__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_5__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__4();
+            rule__ExternalServiceTaskFlowElement__Group_9__3__Impl();
 
             state._fsp--;
 
@@ -17344,121 +17265,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__3"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__3__Impl"
-    // InternalTestgeneratorDSL.g:5565:1: rule__ManualTaskFlowElement__Group_5__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__3__Impl"
+    // InternalTestgeneratorDSL.g:5597:1: rule__ExternalServiceTaskFlowElement__Group_9__3__Impl : ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 ) ) ;
+    public final void rule__ExternalServiceTaskFlowElement__Group_9__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5569:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:5570:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:5601:1: ( ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 ) ) )
+            // InternalTestgeneratorDSL.g:5602:1: ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 ) )
             {
-            // InternalTestgeneratorDSL.g:5570:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:5571:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:5602:1: ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 ) )
+            // InternalTestgeneratorDSL.g:5603:2: ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__3__Impl"
-
-
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__4"
-    // InternalTestgeneratorDSL.g:5580:1: rule__ManualTaskFlowElement__Group_5__4 : rule__ManualTaskFlowElement__Group_5__4__Impl rule__ManualTaskFlowElement__Group_5__5 ;
-    public final void rule__ManualTaskFlowElement__Group_5__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:5584:1: ( rule__ManualTaskFlowElement__Group_5__4__Impl rule__ManualTaskFlowElement__Group_5__5 )
-            // InternalTestgeneratorDSL.g:5585:2: rule__ManualTaskFlowElement__Group_5__4__Impl rule__ManualTaskFlowElement__Group_5__5
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_9_3()); 
+            // InternalTestgeneratorDSL.g:5604:2: ( rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 )
+            // InternalTestgeneratorDSL.g:5604:3: rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_5__4__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__5();
+            rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3();
 
             state._fsp--;
 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__4"
-
-
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__4__Impl"
-    // InternalTestgeneratorDSL.g:5592:1: rule__ManualTaskFlowElement__Group_5__4__Impl : ( ( rule__ManualTaskFlowElement__Group_5_4__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:5596:1: ( ( ( rule__ManualTaskFlowElement__Group_5_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:5597:1: ( ( rule__ManualTaskFlowElement__Group_5_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:5597:1: ( ( rule__ManualTaskFlowElement__Group_5_4__0 )? )
-            // InternalTestgeneratorDSL.g:5598:2: ( rule__ManualTaskFlowElement__Group_5_4__0 )?
-            {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4()); 
-            // InternalTestgeneratorDSL.g:5599:2: ( rule__ManualTaskFlowElement__Group_5_4__0 )?
-            int alt45=2;
-            int LA45_0 = input.LA(1);
-
-            if ( (LA45_0==RULE_ID) ) {
-                alt45=1;
-            }
-            switch (alt45) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:5599:3: rule__ManualTaskFlowElement__Group_5_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_5_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_9_3()); 
 
             }
 
@@ -17477,21 +17312,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__4__Impl"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__5"
-    // InternalTestgeneratorDSL.g:5607:1: rule__ManualTaskFlowElement__Group_5__5 : rule__ManualTaskFlowElement__Group_5__5__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_5__5() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:5613:1: rule__BusinessRuleTaskFlowElement__Group__0 : rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5611:1: ( rule__ManualTaskFlowElement__Group_5__5__Impl )
-            // InternalTestgeneratorDSL.g:5612:2: rule__ManualTaskFlowElement__Group_5__5__Impl
+            // InternalTestgeneratorDSL.g:5617:1: ( rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:5618:2: rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1
             {
+            pushFollow(FOLLOW_4);
+            rule__BusinessRuleTaskFlowElement__Group__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5__5__Impl();
+            rule__BusinessRuleTaskFlowElement__Group__1();
 
             state._fsp--;
 
@@ -17510,25 +17350,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__5"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5__5__Impl"
-    // InternalTestgeneratorDSL.g:5618:1: rule__ManualTaskFlowElement__Group_5__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ManualTaskFlowElement__Group_5__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:5625:1: rule__BusinessRuleTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5622:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:5623:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:5629:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:5630:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:5623:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:5624:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:5630:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:5631:2: 'FlowElement'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -17547,26 +17387,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5__5__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4__0"
-    // InternalTestgeneratorDSL.g:5634:1: rule__ManualTaskFlowElement__Group_5_4__0 : rule__ManualTaskFlowElement__Group_5_4__0__Impl rule__ManualTaskFlowElement__Group_5_4__1 ;
-    public final void rule__ManualTaskFlowElement__Group_5_4__0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:5640:1: rule__BusinessRuleTaskFlowElement__Group__1 : rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5638:1: ( rule__ManualTaskFlowElement__Group_5_4__0__Impl rule__ManualTaskFlowElement__Group_5_4__1 )
-            // InternalTestgeneratorDSL.g:5639:2: rule__ManualTaskFlowElement__Group_5_4__0__Impl rule__ManualTaskFlowElement__Group_5_4__1
+            // InternalTestgeneratorDSL.g:5644:1: ( rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:5645:2: rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2
             {
-            pushFollow(FOLLOW_15);
-            rule__ManualTaskFlowElement__Group_5_4__0__Impl();
+            pushFollow(FOLLOW_12);
+            rule__BusinessRuleTaskFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5_4__1();
+            rule__BusinessRuleTaskFlowElement__Group__2();
 
             state._fsp--;
 
@@ -17585,35 +17425,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4__0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4__0__Impl"
-    // InternalTestgeneratorDSL.g:5646:1: rule__ManualTaskFlowElement__Group_5_4__0__Impl : ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_5_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:5652:1: rule__BusinessRuleTaskFlowElement__Group__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5650:1: ( ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:5651:1: ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
+            // InternalTestgeneratorDSL.g:5656:1: ( ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:5657:1: ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:5651:1: ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
-            // InternalTestgeneratorDSL.g:5652:2: ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 )
+            // InternalTestgeneratorDSL.g:5657:1: ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:5658:2: ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
-            // InternalTestgeneratorDSL.g:5653:2: ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 )
-            // InternalTestgeneratorDSL.g:5653:3: rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:5659:2: ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:5659:3: rule__BusinessRuleTaskFlowElement__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0();
+            rule__BusinessRuleTaskFlowElement__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -17632,21 +17472,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4__0__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4__1"
-    // InternalTestgeneratorDSL.g:5661:1: rule__ManualTaskFlowElement__Group_5_4__1 : rule__ManualTaskFlowElement__Group_5_4__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_5_4__1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:5667:1: rule__BusinessRuleTaskFlowElement__Group__2 : rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5665:1: ( rule__ManualTaskFlowElement__Group_5_4__1__Impl )
-            // InternalTestgeneratorDSL.g:5666:2: rule__ManualTaskFlowElement__Group_5_4__1__Impl
+            // InternalTestgeneratorDSL.g:5671:1: ( rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:5672:2: rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3
             {
+            pushFollow(FOLLOW_34);
+            rule__BusinessRuleTaskFlowElement__Group__2__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5_4__1__Impl();
+            rule__BusinessRuleTaskFlowElement__Group__3();
 
             state._fsp--;
 
@@ -17665,53 +17510,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4__1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4__1__Impl"
-    // InternalTestgeneratorDSL.g:5672:1: rule__ManualTaskFlowElement__Group_5_4__1__Impl : ( ( rule__ManualTaskFlowElement__Group_5_4_1__0 )* ) ;
-    public final void rule__ManualTaskFlowElement__Group_5_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:5679:1: rule__BusinessRuleTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5676:1: ( ( ( rule__ManualTaskFlowElement__Group_5_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:5677:1: ( ( rule__ManualTaskFlowElement__Group_5_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:5683:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5684:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5677:1: ( ( rule__ManualTaskFlowElement__Group_5_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:5678:2: ( rule__ManualTaskFlowElement__Group_5_4_1__0 )*
+            // InternalTestgeneratorDSL.g:5684:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5685:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4_1()); 
-            // InternalTestgeneratorDSL.g:5679:2: ( rule__ManualTaskFlowElement__Group_5_4_1__0 )*
-            loop46:
-            do {
-                int alt46=2;
-                int LA46_0 = input.LA(1);
-
-                if ( (LA46_0==RULE_SEPARATOR) ) {
-                    alt46=1;
-                }
-
-
-                switch (alt46) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:5679:3: rule__ManualTaskFlowElement__Group_5_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ManualTaskFlowElement__Group_5_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop46;
-                }
-            } while (true);
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_5_4_1()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -17730,26 +17547,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4__1__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4_1__0"
-    // InternalTestgeneratorDSL.g:5688:1: rule__ManualTaskFlowElement__Group_5_4_1__0 : rule__ManualTaskFlowElement__Group_5_4_1__0__Impl rule__ManualTaskFlowElement__Group_5_4_1__1 ;
-    public final void rule__ManualTaskFlowElement__Group_5_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:5694:1: rule__BusinessRuleTaskFlowElement__Group__3 : rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5692:1: ( rule__ManualTaskFlowElement__Group_5_4_1__0__Impl rule__ManualTaskFlowElement__Group_5_4_1__1 )
-            // InternalTestgeneratorDSL.g:5693:2: rule__ManualTaskFlowElement__Group_5_4_1__0__Impl rule__ManualTaskFlowElement__Group_5_4_1__1
+            // InternalTestgeneratorDSL.g:5698:1: ( rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:5699:2: rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4
             {
-            pushFollow(FOLLOW_4);
-            rule__ManualTaskFlowElement__Group_5_4_1__0__Impl();
+            pushFollow(FOLLOW_24);
+            rule__BusinessRuleTaskFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5_4_1__1();
+            rule__BusinessRuleTaskFlowElement__Group__4();
 
             state._fsp--;
 
@@ -17768,25 +17585,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4_1__0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:5700:1: rule__ManualTaskFlowElement__Group_5_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ManualTaskFlowElement__Group_5_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:5706:1: rule__BusinessRuleTaskFlowElement__Group__3__Impl : ( 'BusinessRuleTask' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5704:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:5705:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:5710:1: ( ( 'BusinessRuleTask' ) )
+            // InternalTestgeneratorDSL.g:5711:1: ( 'BusinessRuleTask' )
             {
-            // InternalTestgeneratorDSL.g:5705:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:5706:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:5711:1: ( 'BusinessRuleTask' )
+            // InternalTestgeneratorDSL.g:5712:2: 'BusinessRuleTask'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); 
+            match(input,49,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); 
 
             }
 
@@ -17805,21 +17622,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4_1__0__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4_1__1"
-    // InternalTestgeneratorDSL.g:5715:1: rule__ManualTaskFlowElement__Group_5_4_1__1 : rule__ManualTaskFlowElement__Group_5_4_1__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_5_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:5721:1: rule__BusinessRuleTaskFlowElement__Group__4 : rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5719:1: ( rule__ManualTaskFlowElement__Group_5_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:5720:2: rule__ManualTaskFlowElement__Group_5_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:5725:1: ( rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:5726:2: rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5
             {
+            pushFollow(FOLLOW_24);
+            rule__BusinessRuleTaskFlowElement__Group__4__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_5_4_1__1__Impl();
+            rule__BusinessRuleTaskFlowElement__Group__5();
 
             state._fsp--;
 
@@ -17838,35 +17660,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4_1__1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_5_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:5726:1: rule__ManualTaskFlowElement__Group_5_4_1__1__Impl : ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_5_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:5733:1: rule__BusinessRuleTaskFlowElement__Group__4__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5730:1: ( ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:5731:1: ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:5737:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:5738:1: ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:5731:1: ( ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:5732:2: ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
+            // InternalTestgeneratorDSL.g:5738:1: ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:5739:2: ( rule__BusinessRuleTaskFlowElement__Group_4__0 )?
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
-            // InternalTestgeneratorDSL.g:5733:2: ( rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
-            // InternalTestgeneratorDSL.g:5733:3: rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1();
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:5740:2: ( rule__BusinessRuleTaskFlowElement__Group_4__0 )?
+            int alt37=2;
+            int LA37_0 = input.LA(1);
 
-            state._fsp--;
+            if ( (LA37_0==29) ) {
+                alt37=1;
+            }
+            switch (alt37) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:5740:3: rule__BusinessRuleTaskFlowElement__Group_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__BusinessRuleTaskFlowElement__Group_4__0();
+
+                    state._fsp--;
 
 
+                    }
+                    break;
+
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); 
 
             }
 
@@ -17885,26 +17718,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_5_4_1__1__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__0"
-    // InternalTestgeneratorDSL.g:5742:1: rule__ManualTaskFlowElement__Group_6__0 : rule__ManualTaskFlowElement__Group_6__0__Impl rule__ManualTaskFlowElement__Group_6__1 ;
-    public final void rule__ManualTaskFlowElement__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:5748:1: rule__BusinessRuleTaskFlowElement__Group__5 : rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5746:1: ( rule__ManualTaskFlowElement__Group_6__0__Impl rule__ManualTaskFlowElement__Group_6__1 )
-            // InternalTestgeneratorDSL.g:5747:2: rule__ManualTaskFlowElement__Group_6__0__Impl rule__ManualTaskFlowElement__Group_6__1
+            // InternalTestgeneratorDSL.g:5752:1: ( rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6 )
+            // InternalTestgeneratorDSL.g:5753:2: rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6
             {
-            pushFollow(FOLLOW_28);
-            rule__ManualTaskFlowElement__Group_6__0__Impl();
+            pushFollow(FOLLOW_24);
+            rule__BusinessRuleTaskFlowElement__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__1();
+            rule__BusinessRuleTaskFlowElement__Group__6();
 
             state._fsp--;
 
@@ -17923,25 +17756,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:5754:1: rule__ManualTaskFlowElement__Group_6__0__Impl : ( 'with' ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:5760:1: rule__BusinessRuleTaskFlowElement__Group__5__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5758:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:5759:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5764:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:5765:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? )
             {
-            // InternalTestgeneratorDSL.g:5759:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:5760:2: 'with'
+            // InternalTestgeneratorDSL.g:5765:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:5766:2: ( rule__BusinessRuleTaskFlowElement__Group_5__0 )?
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_6_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_6_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); 
+            // InternalTestgeneratorDSL.g:5767:2: ( rule__BusinessRuleTaskFlowElement__Group_5__0 )?
+            int alt38=2;
+            int LA38_0 = input.LA(1);
+
+            if ( (LA38_0==40) ) {
+                alt38=1;
+            }
+            switch (alt38) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:5767:3: rule__BusinessRuleTaskFlowElement__Group_5__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__BusinessRuleTaskFlowElement__Group_5__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); 
 
             }
 
@@ -17960,26 +17814,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__0__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__1"
-    // InternalTestgeneratorDSL.g:5769:1: rule__ManualTaskFlowElement__Group_6__1 : rule__ManualTaskFlowElement__Group_6__1__Impl rule__ManualTaskFlowElement__Group_6__2 ;
-    public final void rule__ManualTaskFlowElement__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__6"
+    // InternalTestgeneratorDSL.g:5775:1: rule__BusinessRuleTaskFlowElement__Group__6 : rule__BusinessRuleTaskFlowElement__Group__6__Impl ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5773:1: ( rule__ManualTaskFlowElement__Group_6__1__Impl rule__ManualTaskFlowElement__Group_6__2 )
-            // InternalTestgeneratorDSL.g:5774:2: rule__ManualTaskFlowElement__Group_6__1__Impl rule__ManualTaskFlowElement__Group_6__2
+            // InternalTestgeneratorDSL.g:5779:1: ( rule__BusinessRuleTaskFlowElement__Group__6__Impl )
+            // InternalTestgeneratorDSL.g:5780:2: rule__BusinessRuleTaskFlowElement__Group__6__Impl
             {
-            pushFollow(FOLLOW_12);
-            rule__ManualTaskFlowElement__Group_6__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__2();
+            rule__BusinessRuleTaskFlowElement__Group__6__Impl();
 
             state._fsp--;
 
@@ -17998,25 +17847,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__6"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:5781:1: rule__ManualTaskFlowElement__Group_6__1__Impl : ( 'outputVariables' ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:5786:1: rule__BusinessRuleTaskFlowElement__Group__6__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5785:1: ( ( 'outputVariables' ) )
-            // InternalTestgeneratorDSL.g:5786:1: ( 'outputVariables' )
+            // InternalTestgeneratorDSL.g:5790:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:5791:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:5786:1: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:5787:2: 'outputVariables'
+            // InternalTestgeneratorDSL.g:5791:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:5792:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
-            match(input,42,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
 
             }
 
@@ -18035,26 +17884,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__1__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__2"
-    // InternalTestgeneratorDSL.g:5796:1: rule__ManualTaskFlowElement__Group_6__2 : rule__ManualTaskFlowElement__Group_6__2__Impl rule__ManualTaskFlowElement__Group_6__3 ;
-    public final void rule__ManualTaskFlowElement__Group_6__2() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__0"
+    // InternalTestgeneratorDSL.g:5802:1: rule__BusinessRuleTaskFlowElement__Group_4__0 : rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5800:1: ( rule__ManualTaskFlowElement__Group_6__2__Impl rule__ManualTaskFlowElement__Group_6__3 )
-            // InternalTestgeneratorDSL.g:5801:2: rule__ManualTaskFlowElement__Group_6__2__Impl rule__ManualTaskFlowElement__Group_6__3
+            // InternalTestgeneratorDSL.g:5806:1: ( rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:5807:2: rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1
             {
-            pushFollow(FOLLOW_13);
-            rule__ManualTaskFlowElement__Group_6__2__Impl();
+            pushFollow(FOLLOW_35);
+            rule__BusinessRuleTaskFlowElement__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__3();
+            rule__BusinessRuleTaskFlowElement__Group_4__1();
 
             state._fsp--;
 
@@ -18073,25 +17922,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__2"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__2__Impl"
-    // InternalTestgeneratorDSL.g:5808:1: rule__ManualTaskFlowElement__Group_6__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:5814:1: rule__BusinessRuleTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5812:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:5813:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5818:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:5819:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:5813:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:5814:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:5819:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:5820:2: 'with'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); 
 
             }
 
@@ -18110,26 +17959,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__2__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__3"
-    // InternalTestgeneratorDSL.g:5823:1: rule__ManualTaskFlowElement__Group_6__3 : rule__ManualTaskFlowElement__Group_6__3__Impl rule__ManualTaskFlowElement__Group_6__4 ;
-    public final void rule__ManualTaskFlowElement__Group_6__3() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__1"
+    // InternalTestgeneratorDSL.g:5829:1: rule__BusinessRuleTaskFlowElement__Group_4__1 : rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5827:1: ( rule__ManualTaskFlowElement__Group_6__3__Impl rule__ManualTaskFlowElement__Group_6__4 )
-            // InternalTestgeneratorDSL.g:5828:2: rule__ManualTaskFlowElement__Group_6__3__Impl rule__ManualTaskFlowElement__Group_6__4
+            // InternalTestgeneratorDSL.g:5833:1: ( rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:5834:2: rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_6__3__Impl();
+            pushFollow(FOLLOW_12);
+            rule__BusinessRuleTaskFlowElement__Group_4__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__4();
+            rule__BusinessRuleTaskFlowElement__Group_4__2();
 
             state._fsp--;
 
@@ -18148,25 +17997,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__3"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__3__Impl"
-    // InternalTestgeneratorDSL.g:5835:1: rule__ManualTaskFlowElement__Group_6__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:5841:1: rule__BusinessRuleTaskFlowElement__Group_4__1__Impl : ( 'resultVariable' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5839:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:5840:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:5845:1: ( ( 'resultVariable' ) )
+            // InternalTestgeneratorDSL.g:5846:1: ( 'resultVariable' )
             {
-            // InternalTestgeneratorDSL.g:5840:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:5841:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:5846:1: ( 'resultVariable' )
+            // InternalTestgeneratorDSL.g:5847:2: 'resultVariable'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); 
+            match(input,50,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); 
 
             }
 
@@ -18185,26 +18034,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__3__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__4"
-    // InternalTestgeneratorDSL.g:5850:1: rule__ManualTaskFlowElement__Group_6__4 : rule__ManualTaskFlowElement__Group_6__4__Impl rule__ManualTaskFlowElement__Group_6__5 ;
-    public final void rule__ManualTaskFlowElement__Group_6__4() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__2"
+    // InternalTestgeneratorDSL.g:5856:1: rule__BusinessRuleTaskFlowElement__Group_4__2 : rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5854:1: ( rule__ManualTaskFlowElement__Group_6__4__Impl rule__ManualTaskFlowElement__Group_6__5 )
-            // InternalTestgeneratorDSL.g:5855:2: rule__ManualTaskFlowElement__Group_6__4__Impl rule__ManualTaskFlowElement__Group_6__5
+            // InternalTestgeneratorDSL.g:5860:1: ( rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:5861:2: rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_21);
-            rule__ManualTaskFlowElement__Group_6__4__Impl();
+            pushFollow(FOLLOW_7);
+            rule__BusinessRuleTaskFlowElement__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__5();
+            rule__BusinessRuleTaskFlowElement__Group_4__3();
 
             state._fsp--;
 
@@ -18223,46 +18072,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__4"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__4__Impl"
-    // InternalTestgeneratorDSL.g:5862:1: rule__ManualTaskFlowElement__Group_6__4__Impl : ( ( rule__ManualTaskFlowElement__Group_6_4__0 )? ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:5868:1: rule__BusinessRuleTaskFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5866:1: ( ( ( rule__ManualTaskFlowElement__Group_6_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:5867:1: ( ( rule__ManualTaskFlowElement__Group_6_4__0 )? )
+            // InternalTestgeneratorDSL.g:5872:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5873:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5867:1: ( ( rule__ManualTaskFlowElement__Group_6_4__0 )? )
-            // InternalTestgeneratorDSL.g:5868:2: ( rule__ManualTaskFlowElement__Group_6_4__0 )?
+            // InternalTestgeneratorDSL.g:5873:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5874:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4()); 
-            // InternalTestgeneratorDSL.g:5869:2: ( rule__ManualTaskFlowElement__Group_6_4__0 )?
-            int alt47=2;
-            int LA47_0 = input.LA(1);
-
-            if ( (LA47_0==RULE_ID) ) {
-                alt47=1;
-            }
-            switch (alt47) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:5869:3: rule__ManualTaskFlowElement__Group_6_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ManualTaskFlowElement__Group_6_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -18281,21 +18109,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__4__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__5"
-    // InternalTestgeneratorDSL.g:5877:1: rule__ManualTaskFlowElement__Group_6__5 : rule__ManualTaskFlowElement__Group_6__5__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_6__5() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__3"
+    // InternalTestgeneratorDSL.g:5883:1: rule__BusinessRuleTaskFlowElement__Group_4__3 : rule__BusinessRuleTaskFlowElement__Group_4__3__Impl ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5881:1: ( rule__ManualTaskFlowElement__Group_6__5__Impl )
-            // InternalTestgeneratorDSL.g:5882:2: rule__ManualTaskFlowElement__Group_6__5__Impl
+            // InternalTestgeneratorDSL.g:5887:1: ( rule__BusinessRuleTaskFlowElement__Group_4__3__Impl )
+            // InternalTestgeneratorDSL.g:5888:2: rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6__5__Impl();
+            rule__BusinessRuleTaskFlowElement__Group_4__3__Impl();
 
             state._fsp--;
 
@@ -18314,25 +18142,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__5"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6__5__Impl"
-    // InternalTestgeneratorDSL.g:5888:1: rule__ManualTaskFlowElement__Group_6__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ManualTaskFlowElement__Group_6__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:5894:1: rule__BusinessRuleTaskFlowElement__Group_4__3__Impl : ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5892:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:5893:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:5898:1: ( ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) ) )
+            // InternalTestgeneratorDSL.g:5899:1: ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) )
             {
-            // InternalTestgeneratorDSL.g:5893:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:5894:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:5899:1: ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:5900:2: ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); 
+            // InternalTestgeneratorDSL.g:5901:2: ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:5901:3: rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); 
 
             }
 
@@ -18351,26 +18189,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6__5__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4__0"
-    // InternalTestgeneratorDSL.g:5904:1: rule__ManualTaskFlowElement__Group_6_4__0 : rule__ManualTaskFlowElement__Group_6_4__0__Impl rule__ManualTaskFlowElement__Group_6_4__1 ;
-    public final void rule__ManualTaskFlowElement__Group_6_4__0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__0"
+    // InternalTestgeneratorDSL.g:5910:1: rule__BusinessRuleTaskFlowElement__Group_5__0 : rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5908:1: ( rule__ManualTaskFlowElement__Group_6_4__0__Impl rule__ManualTaskFlowElement__Group_6_4__1 )
-            // InternalTestgeneratorDSL.g:5909:2: rule__ManualTaskFlowElement__Group_6_4__0__Impl rule__ManualTaskFlowElement__Group_6_4__1
+            // InternalTestgeneratorDSL.g:5914:1: ( rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1 )
+            // InternalTestgeneratorDSL.g:5915:2: rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1
             {
-            pushFollow(FOLLOW_15);
-            rule__ManualTaskFlowElement__Group_6_4__0__Impl();
+            pushFollow(FOLLOW_25);
+            rule__BusinessRuleTaskFlowElement__Group_5__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6_4__1();
+            rule__BusinessRuleTaskFlowElement__Group_5__1();
 
             state._fsp--;
 
@@ -18389,35 +18227,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4__0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4__0__Impl"
-    // InternalTestgeneratorDSL.g:5916:1: rule__ManualTaskFlowElement__Group_6_4__0__Impl : ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_6_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__0__Impl"
+    // InternalTestgeneratorDSL.g:5922:1: rule__BusinessRuleTaskFlowElement__Group_5__0__Impl : ( 'and' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5920:1: ( ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:5921:1: ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:5921:1: ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
-            // InternalTestgeneratorDSL.g:5922:2: ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 )
+            // InternalTestgeneratorDSL.g:5926:1: ( ( 'and' ) )
+            // InternalTestgeneratorDSL.g:5927:1: ( 'and' )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
-            // InternalTestgeneratorDSL.g:5923:2: ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 )
-            // InternalTestgeneratorDSL.g:5923:3: rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0
+            // InternalTestgeneratorDSL.g:5927:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:5928:2: 'and'
             {
-            pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_5_0()); 
+            match(input,40,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_5_0()); 
 
             }
 
@@ -18436,21 +18264,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4__0__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4__1"
-    // InternalTestgeneratorDSL.g:5931:1: rule__ManualTaskFlowElement__Group_6_4__1 : rule__ManualTaskFlowElement__Group_6_4__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_6_4__1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__1"
+    // InternalTestgeneratorDSL.g:5937:1: rule__BusinessRuleTaskFlowElement__Group_5__1 : rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5935:1: ( rule__ManualTaskFlowElement__Group_6_4__1__Impl )
-            // InternalTestgeneratorDSL.g:5936:2: rule__ManualTaskFlowElement__Group_6_4__1__Impl
+            // InternalTestgeneratorDSL.g:5941:1: ( rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2 )
+            // InternalTestgeneratorDSL.g:5942:2: rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2
             {
+            pushFollow(FOLLOW_12);
+            rule__BusinessRuleTaskFlowElement__Group_5__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6_4__1__Impl();
+            rule__BusinessRuleTaskFlowElement__Group_5__2();
 
             state._fsp--;
 
@@ -18469,53 +18302,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4__1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4__1__Impl"
-    // InternalTestgeneratorDSL.g:5942:1: rule__ManualTaskFlowElement__Group_6_4__1__Impl : ( ( rule__ManualTaskFlowElement__Group_6_4_1__0 )* ) ;
-    public final void rule__ManualTaskFlowElement__Group_6_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__1__Impl"
+    // InternalTestgeneratorDSL.g:5949:1: rule__BusinessRuleTaskFlowElement__Group_5__1__Impl : ( 'label' ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5946:1: ( ( ( rule__ManualTaskFlowElement__Group_6_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:5947:1: ( ( rule__ManualTaskFlowElement__Group_6_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:5953:1: ( ( 'label' ) )
+            // InternalTestgeneratorDSL.g:5954:1: ( 'label' )
             {
-            // InternalTestgeneratorDSL.g:5947:1: ( ( rule__ManualTaskFlowElement__Group_6_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:5948:2: ( rule__ManualTaskFlowElement__Group_6_4_1__0 )*
+            // InternalTestgeneratorDSL.g:5954:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:5955:2: 'label'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4_1()); 
-            // InternalTestgeneratorDSL.g:5949:2: ( rule__ManualTaskFlowElement__Group_6_4_1__0 )*
-            loop48:
-            do {
-                int alt48=2;
-                int LA48_0 = input.LA(1);
-
-                if ( (LA48_0==RULE_SEPARATOR) ) {
-                    alt48=1;
-                }
-
-
-                switch (alt48) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:5949:3: rule__ManualTaskFlowElement__Group_6_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ManualTaskFlowElement__Group_6_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop48;
-                }
-            } while (true);
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getGroup_6_4_1()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_5_1()); 
+            match(input,41,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_5_1()); 
 
             }
 
@@ -18534,26 +18339,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4__1__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4_1__0"
-    // InternalTestgeneratorDSL.g:5958:1: rule__ManualTaskFlowElement__Group_6_4_1__0 : rule__ManualTaskFlowElement__Group_6_4_1__0__Impl rule__ManualTaskFlowElement__Group_6_4_1__1 ;
-    public final void rule__ManualTaskFlowElement__Group_6_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__2"
+    // InternalTestgeneratorDSL.g:5964:1: rule__BusinessRuleTaskFlowElement__Group_5__2 : rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3 ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5962:1: ( rule__ManualTaskFlowElement__Group_6_4_1__0__Impl rule__ManualTaskFlowElement__Group_6_4_1__1 )
-            // InternalTestgeneratorDSL.g:5963:2: rule__ManualTaskFlowElement__Group_6_4_1__0__Impl rule__ManualTaskFlowElement__Group_6_4_1__1
+            // InternalTestgeneratorDSL.g:5968:1: ( rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3 )
+            // InternalTestgeneratorDSL.g:5969:2: rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3
             {
-            pushFollow(FOLLOW_4);
-            rule__ManualTaskFlowElement__Group_6_4_1__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__BusinessRuleTaskFlowElement__Group_5__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6_4_1__1();
+            rule__BusinessRuleTaskFlowElement__Group_5__3();
 
             state._fsp--;
 
@@ -18572,25 +18377,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4_1__0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:5970:1: rule__ManualTaskFlowElement__Group_6_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ManualTaskFlowElement__Group_6_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__2__Impl"
+    // InternalTestgeneratorDSL.g:5976:1: rule__BusinessRuleTaskFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5974:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:5975:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:5980:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:5981:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:5975:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:5976:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:5981:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:5982:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
 
             }
 
@@ -18609,21 +18414,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4_1__0__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4_1__1"
-    // InternalTestgeneratorDSL.g:5985:1: rule__ManualTaskFlowElement__Group_6_4_1__1 : rule__ManualTaskFlowElement__Group_6_4_1__1__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_6_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__3"
+    // InternalTestgeneratorDSL.g:5991:1: rule__BusinessRuleTaskFlowElement__Group_5__3 : rule__BusinessRuleTaskFlowElement__Group_5__3__Impl ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:5989:1: ( rule__ManualTaskFlowElement__Group_6_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:5990:2: rule__ManualTaskFlowElement__Group_6_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:5995:1: ( rule__BusinessRuleTaskFlowElement__Group_5__3__Impl )
+            // InternalTestgeneratorDSL.g:5996:2: rule__BusinessRuleTaskFlowElement__Group_5__3__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_6_4_1__1__Impl();
+            rule__BusinessRuleTaskFlowElement__Group_5__3__Impl();
 
             state._fsp--;
 
@@ -18642,35 +18447,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4_1__1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_6_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:5996:1: rule__ManualTaskFlowElement__Group_6_4_1__1__Impl : ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_6_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__3__Impl"
+    // InternalTestgeneratorDSL.g:6002:1: rule__BusinessRuleTaskFlowElement__Group_5__3__Impl : ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 ) ) ;
+    public final void rule__BusinessRuleTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6000:1: ( ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:6001:1: ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:6006:1: ( ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 ) ) )
+            // InternalTestgeneratorDSL.g:6007:1: ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 ) )
             {
-            // InternalTestgeneratorDSL.g:6001:1: ( ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:6002:2: ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
+            // InternalTestgeneratorDSL.g:6007:1: ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 ) )
+            // InternalTestgeneratorDSL.g:6008:2: ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
-            // InternalTestgeneratorDSL.g:6003:2: ( rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
-            // InternalTestgeneratorDSL.g:6003:3: rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_5_3()); 
+            // InternalTestgeneratorDSL.g:6009:2: ( rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 )
+            // InternalTestgeneratorDSL.g:6009:3: rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3
             {
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1();
+            rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_5_3()); 
 
             }
 
@@ -18689,26 +18494,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_6_4_1__1__Impl"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__3__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__0"
-    // InternalTestgeneratorDSL.g:6012:1: rule__ManualTaskFlowElement__Group_7__0 : rule__ManualTaskFlowElement__Group_7__0__Impl rule__ManualTaskFlowElement__Group_7__1 ;
-    public final void rule__ManualTaskFlowElement__Group_7__0() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:6018:1: rule__GatewayFlowElement__Group__0 : rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1 ;
+    public final void rule__GatewayFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6016:1: ( rule__ManualTaskFlowElement__Group_7__0__Impl rule__ManualTaskFlowElement__Group_7__1 )
-            // InternalTestgeneratorDSL.g:6017:2: rule__ManualTaskFlowElement__Group_7__0__Impl rule__ManualTaskFlowElement__Group_7__1
+            // InternalTestgeneratorDSL.g:6022:1: ( rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:6023:2: rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1
             {
-            pushFollow(FOLLOW_29);
-            rule__ManualTaskFlowElement__Group_7__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__GatewayFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_7__1();
+            rule__GatewayFlowElement__Group__1();
 
             state._fsp--;
 
@@ -18727,25 +18532,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__0"
+    // $ANTLR end "rule__GatewayFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:6024:1: rule__ManualTaskFlowElement__Group_7__0__Impl : ( 'and' ) ;
-    public final void rule__ManualTaskFlowElement__Group_7__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6030:1: rule__GatewayFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__GatewayFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6028:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:6029:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:6034:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:6035:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:6029:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:6030:2: 'and'
+            // InternalTestgeneratorDSL.g:6035:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:6036:2: 'FlowElement'
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_7_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_7_0()); 
+             before(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -18764,26 +18569,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__0__Impl"
+    // $ANTLR end "rule__GatewayFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__1"
-    // InternalTestgeneratorDSL.g:6039:1: rule__ManualTaskFlowElement__Group_7__1 : rule__ManualTaskFlowElement__Group_7__1__Impl rule__ManualTaskFlowElement__Group_7__2 ;
-    public final void rule__ManualTaskFlowElement__Group_7__1() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:6045:1: rule__GatewayFlowElement__Group__1 : rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2 ;
+    public final void rule__GatewayFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6043:1: ( rule__ManualTaskFlowElement__Group_7__1__Impl rule__ManualTaskFlowElement__Group_7__2 )
-            // InternalTestgeneratorDSL.g:6044:2: rule__ManualTaskFlowElement__Group_7__1__Impl rule__ManualTaskFlowElement__Group_7__2
+            // InternalTestgeneratorDSL.g:6049:1: ( rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:6050:2: rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__ManualTaskFlowElement__Group_7__1__Impl();
+            rule__GatewayFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_7__2();
+            rule__GatewayFlowElement__Group__2();
 
             state._fsp--;
 
@@ -18802,25 +18607,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__1"
+    // $ANTLR end "rule__GatewayFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:6051:1: rule__ManualTaskFlowElement__Group_7__1__Impl : ( 'label' ) ;
-    public final void rule__ManualTaskFlowElement__Group_7__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:6057:1: rule__GatewayFlowElement__Group__1__Impl : ( ( rule__GatewayFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__GatewayFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6055:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:6056:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:6061:1: ( ( ( rule__GatewayFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:6062:1: ( ( rule__GatewayFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6056:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:6057:2: 'label'
+            // InternalTestgeneratorDSL.g:6062:1: ( ( rule__GatewayFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:6063:2: ( rule__GatewayFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_7_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_7_1()); 
+             before(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:6064:2: ( rule__GatewayFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:6064:3: rule__GatewayFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__GatewayFlowElement__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -18839,26 +18654,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__1__Impl"
+    // $ANTLR end "rule__GatewayFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__2"
-    // InternalTestgeneratorDSL.g:6066:1: rule__ManualTaskFlowElement__Group_7__2 : rule__ManualTaskFlowElement__Group_7__2__Impl rule__ManualTaskFlowElement__Group_7__3 ;
-    public final void rule__ManualTaskFlowElement__Group_7__2() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:6072:1: rule__GatewayFlowElement__Group__2 : rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3 ;
+    public final void rule__GatewayFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6070:1: ( rule__ManualTaskFlowElement__Group_7__2__Impl rule__ManualTaskFlowElement__Group_7__3 )
-            // InternalTestgeneratorDSL.g:6071:2: rule__ManualTaskFlowElement__Group_7__2__Impl rule__ManualTaskFlowElement__Group_7__3
+            // InternalTestgeneratorDSL.g:6076:1: ( rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:6077:2: rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3
             {
-            pushFollow(FOLLOW_7);
-            rule__ManualTaskFlowElement__Group_7__2__Impl();
+            pushFollow(FOLLOW_36);
+            rule__GatewayFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_7__3();
+            rule__GatewayFlowElement__Group__3();
 
             state._fsp--;
 
@@ -18877,25 +18692,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__2"
+    // $ANTLR end "rule__GatewayFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__2__Impl"
-    // InternalTestgeneratorDSL.g:6078:1: rule__ManualTaskFlowElement__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ManualTaskFlowElement__Group_7__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:6084:1: rule__GatewayFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__GatewayFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6082:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:6083:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6088:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:6089:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:6083:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:6084:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:6089:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6090:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             before(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             after(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -18914,21 +18729,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__2__Impl"
+    // $ANTLR end "rule__GatewayFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__3"
-    // InternalTestgeneratorDSL.g:6093:1: rule__ManualTaskFlowElement__Group_7__3 : rule__ManualTaskFlowElement__Group_7__3__Impl ;
-    public final void rule__ManualTaskFlowElement__Group_7__3() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:6099:1: rule__GatewayFlowElement__Group__3 : rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4 ;
+    public final void rule__GatewayFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6097:1: ( rule__ManualTaskFlowElement__Group_7__3__Impl )
-            // InternalTestgeneratorDSL.g:6098:2: rule__ManualTaskFlowElement__Group_7__3__Impl
+            // InternalTestgeneratorDSL.g:6103:1: ( rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:6104:2: rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4
             {
+            pushFollow(FOLLOW_22);
+            rule__GatewayFlowElement__Group__3__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__Group_7__3__Impl();
+            rule__GatewayFlowElement__Group__4();
 
             state._fsp--;
 
@@ -18947,35 +18767,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__3"
+    // $ANTLR end "rule__GatewayFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__Group_7__3__Impl"
-    // InternalTestgeneratorDSL.g:6104:1: rule__ManualTaskFlowElement__Group_7__3__Impl : ( ( rule__ManualTaskFlowElement__LabelAssignment_7_3 ) ) ;
-    public final void rule__ManualTaskFlowElement__Group_7__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:6111:1: rule__GatewayFlowElement__Group__3__Impl : ( 'Gateway' ) ;
+    public final void rule__GatewayFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6108:1: ( ( ( rule__ManualTaskFlowElement__LabelAssignment_7_3 ) ) )
-            // InternalTestgeneratorDSL.g:6109:1: ( ( rule__ManualTaskFlowElement__LabelAssignment_7_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:6109:1: ( ( rule__ManualTaskFlowElement__LabelAssignment_7_3 ) )
-            // InternalTestgeneratorDSL.g:6110:2: ( rule__ManualTaskFlowElement__LabelAssignment_7_3 )
+            // InternalTestgeneratorDSL.g:6115:1: ( ( 'Gateway' ) )
+            // InternalTestgeneratorDSL.g:6116:1: ( 'Gateway' )
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_7_3()); 
-            // InternalTestgeneratorDSL.g:6111:2: ( rule__ManualTaskFlowElement__LabelAssignment_7_3 )
-            // InternalTestgeneratorDSL.g:6111:3: rule__ManualTaskFlowElement__LabelAssignment_7_3
+            // InternalTestgeneratorDSL.g:6116:1: ( 'Gateway' )
+            // InternalTestgeneratorDSL.g:6117:2: 'Gateway'
             {
-            pushFollow(FOLLOW_2);
-            rule__ManualTaskFlowElement__LabelAssignment_7_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getLabelAssignment_7_3()); 
+             before(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); 
+            match(input,51,FOLLOW_2); 
+             after(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); 
 
             }
 
@@ -18994,26 +18804,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__Group_7__3__Impl"
+    // $ANTLR end "rule__GatewayFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:6120:1: rule__ScriptTaskFlowElement__Group__0 : rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1 ;
-    public final void rule__ScriptTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:6126:1: rule__GatewayFlowElement__Group__4 : rule__GatewayFlowElement__Group__4__Impl ;
+    public final void rule__GatewayFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6124:1: ( rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:6125:2: rule__ScriptTaskFlowElement__Group__0__Impl rule__ScriptTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:6130:1: ( rule__GatewayFlowElement__Group__4__Impl )
+            // InternalTestgeneratorDSL.g:6131:2: rule__GatewayFlowElement__Group__4__Impl
             {
-            pushFollow(FOLLOW_4);
-            rule__ScriptTaskFlowElement__Group__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__1();
+            rule__GatewayFlowElement__Group__4__Impl();
 
             state._fsp--;
 
@@ -19032,25 +18837,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__0"
+    // $ANTLR end "rule__GatewayFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:6132:1: rule__ScriptTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__ScriptTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__GatewayFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:6137:1: rule__GatewayFlowElement__Group__4__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__GatewayFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6136:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:6137:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:6141:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:6142:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:6137:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:6138:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:6142:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:6143:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
 
             }
 
@@ -19069,26 +18874,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__GatewayFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:6147:1: rule__ScriptTaskFlowElement__Group__1 : rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2 ;
-    public final void rule__ScriptTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__0"
+    // InternalTestgeneratorDSL.g:6153:1: rule__SequenceFlowElement__Group__0 : rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1 ;
+    public final void rule__SequenceFlowElement__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6151:1: ( rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:6152:2: rule__ScriptTaskFlowElement__Group__1__Impl rule__ScriptTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:6157:1: ( rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1 )
+            // InternalTestgeneratorDSL.g:6158:2: rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1
             {
-            pushFollow(FOLLOW_12);
-            rule__ScriptTaskFlowElement__Group__1__Impl();
+            pushFollow(FOLLOW_4);
+            rule__SequenceFlowElement__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__2();
+            rule__SequenceFlowElement__Group__1();
 
             state._fsp--;
 
@@ -19107,35 +18912,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__1"
+    // $ANTLR end "rule__SequenceFlowElement__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:6159:1: rule__ScriptTaskFlowElement__Group__1__Impl : ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6165:1: rule__SequenceFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
+    public final void rule__SequenceFlowElement__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6163:1: ( ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:6164:1: ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:6169:1: ( ( 'FlowElement' ) )
+            // InternalTestgeneratorDSL.g:6170:1: ( 'FlowElement' )
             {
-            // InternalTestgeneratorDSL.g:6164:1: ( ( rule__ScriptTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:6165:2: ( rule__ScriptTaskFlowElement__NameAssignment_1 )
-            {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:6166:2: ( rule__ScriptTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:6166:3: rule__ScriptTaskFlowElement__NameAssignment_1
+            // InternalTestgeneratorDSL.g:6170:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:6171:2: 'FlowElement'
             {
-            pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); 
+            match(input,35,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); 
 
             }
 
@@ -19154,26 +18949,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:6174:1: rule__ScriptTaskFlowElement__Group__2 : rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3 ;
-    public final void rule__ScriptTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__1"
+    // InternalTestgeneratorDSL.g:6180:1: rule__SequenceFlowElement__Group__1 : rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2 ;
+    public final void rule__SequenceFlowElement__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6178:1: ( rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:6179:2: rule__ScriptTaskFlowElement__Group__2__Impl rule__ScriptTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:6184:1: ( rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2 )
+            // InternalTestgeneratorDSL.g:6185:2: rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2
             {
-            pushFollow(FOLLOW_31);
-            rule__ScriptTaskFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_12);
+            rule__SequenceFlowElement__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__3();
+            rule__SequenceFlowElement__Group__2();
 
             state._fsp--;
 
@@ -19192,25 +18987,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__2"
+    // $ANTLR end "rule__SequenceFlowElement__Group__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:6186:1: rule__ScriptTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ScriptTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:6192:1: rule__SequenceFlowElement__Group__1__Impl : ( ( rule__SequenceFlowElement__NameAssignment_1 ) ) ;
+    public final void rule__SequenceFlowElement__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6190:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:6191:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6196:1: ( ( ( rule__SequenceFlowElement__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:6197:1: ( ( rule__SequenceFlowElement__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6191:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:6192:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:6197:1: ( ( rule__SequenceFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:6198:2: ( rule__SequenceFlowElement__NameAssignment_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:6199:2: ( rule__SequenceFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:6199:3: rule__SequenceFlowElement__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__SequenceFlowElement__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); 
 
             }
 
@@ -19229,26 +19034,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:6201:1: rule__ScriptTaskFlowElement__Group__3 : rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4 ;
-    public final void rule__ScriptTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__2"
+    // InternalTestgeneratorDSL.g:6207:1: rule__SequenceFlowElement__Group__2 : rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3 ;
+    public final void rule__SequenceFlowElement__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6205:1: ( rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:6206:2: rule__ScriptTaskFlowElement__Group__3__Impl rule__ScriptTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:6211:1: ( rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3 )
+            // InternalTestgeneratorDSL.g:6212:2: rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3
             {
-            pushFollow(FOLLOW_26);
-            rule__ScriptTaskFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_37);
+            rule__SequenceFlowElement__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__4();
+            rule__SequenceFlowElement__Group__3();
 
             state._fsp--;
 
@@ -19267,25 +19072,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__3"
+    // $ANTLR end "rule__SequenceFlowElement__Group__2"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:6213:1: rule__ScriptTaskFlowElement__Group__3__Impl : ( 'ScriptTask' ) ;
-    public final void rule__ScriptTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:6219:1: rule__SequenceFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__SequenceFlowElement__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6217:1: ( ( 'ScriptTask' ) )
-            // InternalTestgeneratorDSL.g:6218:1: ( 'ScriptTask' )
+            // InternalTestgeneratorDSL.g:6223:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:6224:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:6218:1: ( 'ScriptTask' )
-            // InternalTestgeneratorDSL.g:6219:2: 'ScriptTask'
+            // InternalTestgeneratorDSL.g:6224:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6225:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); 
-            match(input,46,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -19304,26 +19109,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:6228:1: rule__ScriptTaskFlowElement__Group__4 : rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5 ;
-    public final void rule__ScriptTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__3"
+    // InternalTestgeneratorDSL.g:6234:1: rule__SequenceFlowElement__Group__3 : rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4 ;
+    public final void rule__SequenceFlowElement__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6232:1: ( rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:6233:2: rule__ScriptTaskFlowElement__Group__4__Impl rule__ScriptTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:6238:1: ( rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4 )
+            // InternalTestgeneratorDSL.g:6239:2: rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4
             {
-            pushFollow(FOLLOW_26);
-            rule__ScriptTaskFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_10);
+            rule__SequenceFlowElement__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__5();
+            rule__SequenceFlowElement__Group__4();
 
             state._fsp--;
 
@@ -19342,50 +19147,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__4"
+    // $ANTLR end "rule__SequenceFlowElement__Group__3"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:6240:1: rule__ScriptTaskFlowElement__Group__4__Impl : ( ( rule__ScriptTaskFlowElement__Group_4__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:6246:1: rule__SequenceFlowElement__Group__3__Impl : ( 'SequenceFlow' ) ;
+    public final void rule__SequenceFlowElement__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6244:1: ( ( ( rule__ScriptTaskFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:6245:1: ( ( rule__ScriptTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:6250:1: ( ( 'SequenceFlow' ) )
+            // InternalTestgeneratorDSL.g:6251:1: ( 'SequenceFlow' )
             {
-            // InternalTestgeneratorDSL.g:6245:1: ( ( rule__ScriptTaskFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:6246:2: ( rule__ScriptTaskFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:6251:1: ( 'SequenceFlow' )
+            // InternalTestgeneratorDSL.g:6252:2: 'SequenceFlow'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:6247:2: ( rule__ScriptTaskFlowElement__Group_4__0 )?
-            int alt49=2;
-            int LA49_0 = input.LA(1);
-
-            if ( (LA49_0==28) ) {
-                int LA49_1 = input.LA(2);
-
-                if ( (LA49_1==36) ) {
-                    alt49=1;
-                }
-            }
-            switch (alt49) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:6247:3: rule__ScriptTaskFlowElement__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); 
+            match(input,52,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); 
 
             }
 
@@ -19404,26 +19184,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:6255:1: rule__ScriptTaskFlowElement__Group__5 : rule__ScriptTaskFlowElement__Group__5__Impl rule__ScriptTaskFlowElement__Group__6 ;
-    public final void rule__ScriptTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__4"
+    // InternalTestgeneratorDSL.g:6261:1: rule__SequenceFlowElement__Group__4 : rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5 ;
+    public final void rule__SequenceFlowElement__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6259:1: ( rule__ScriptTaskFlowElement__Group__5__Impl rule__ScriptTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:6260:2: rule__ScriptTaskFlowElement__Group__5__Impl rule__ScriptTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:6265:1: ( rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5 )
+            // InternalTestgeneratorDSL.g:6266:2: rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5
             {
-            pushFollow(FOLLOW_26);
-            rule__ScriptTaskFlowElement__Group__5__Impl();
+            pushFollow(FOLLOW_10);
+            rule__SequenceFlowElement__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__6();
+            rule__SequenceFlowElement__Group__5();
 
             state._fsp--;
 
@@ -19442,40 +19222,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__5"
+    // $ANTLR end "rule__SequenceFlowElement__Group__4"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:6267:1: rule__ScriptTaskFlowElement__Group__5__Impl : ( ( rule__ScriptTaskFlowElement__Group_5__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:6273:1: rule__SequenceFlowElement__Group__4__Impl : ( ( rule__SequenceFlowElement__Group_4__0 )? ) ;
+    public final void rule__SequenceFlowElement__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6271:1: ( ( ( rule__ScriptTaskFlowElement__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:6272:1: ( ( rule__ScriptTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:6277:1: ( ( ( rule__SequenceFlowElement__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:6278:1: ( ( rule__SequenceFlowElement__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:6272:1: ( ( rule__ScriptTaskFlowElement__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:6273:2: ( rule__ScriptTaskFlowElement__Group_5__0 )?
+            // InternalTestgeneratorDSL.g:6278:1: ( ( rule__SequenceFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:6279:2: ( rule__SequenceFlowElement__Group_4__0 )?
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:6274:2: ( rule__ScriptTaskFlowElement__Group_5__0 )?
-            int alt50=2;
-            int LA50_0 = input.LA(1);
-
-            if ( (LA50_0==28) ) {
-                int LA50_1 = input.LA(2);
+             before(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:6280:2: ( rule__SequenceFlowElement__Group_4__0 )?
+            int alt39=2;
+            int LA39_0 = input.LA(1);
 
-                if ( (LA50_1==41) ) {
-                    alt50=1;
-                }
+            if ( (LA39_0==29) ) {
+                alt39=1;
             }
-            switch (alt50) {
+            switch (alt39) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:6274:3: rule__ScriptTaskFlowElement__Group_5__0
+                    // InternalTestgeneratorDSL.g:6280:3: rule__SequenceFlowElement__Group_4__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_5__0();
+                    rule__SequenceFlowElement__Group_4__0();
 
                     state._fsp--;
 
@@ -19485,7 +19261,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5()); 
+             after(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); 
 
             }
 
@@ -19504,26 +19280,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:6282:1: rule__ScriptTaskFlowElement__Group__6 : rule__ScriptTaskFlowElement__Group__6__Impl rule__ScriptTaskFlowElement__Group__7 ;
-    public final void rule__ScriptTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__5"
+    // InternalTestgeneratorDSL.g:6288:1: rule__SequenceFlowElement__Group__5 : rule__SequenceFlowElement__Group__5__Impl ;
+    public final void rule__SequenceFlowElement__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6286:1: ( rule__ScriptTaskFlowElement__Group__6__Impl rule__ScriptTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:6287:2: rule__ScriptTaskFlowElement__Group__6__Impl rule__ScriptTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:6292:1: ( rule__SequenceFlowElement__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:6293:2: rule__SequenceFlowElement__Group__5__Impl
             {
-            pushFollow(FOLLOW_26);
-            rule__ScriptTaskFlowElement__Group__6__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__7();
+            rule__SequenceFlowElement__Group__5__Impl();
 
             state._fsp--;
 
@@ -19542,46 +19313,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__6"
+    // $ANTLR end "rule__SequenceFlowElement__Group__5"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:6294:1: rule__ScriptTaskFlowElement__Group__6__Impl : ( ( rule__ScriptTaskFlowElement__Group_6__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:6299:1: rule__SequenceFlowElement__Group__5__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__SequenceFlowElement__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6298:1: ( ( ( rule__ScriptTaskFlowElement__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:6299:1: ( ( rule__ScriptTaskFlowElement__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:6303:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:6304:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:6299:1: ( ( rule__ScriptTaskFlowElement__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:6300:2: ( rule__ScriptTaskFlowElement__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:6304:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:6305:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:6301:2: ( rule__ScriptTaskFlowElement__Group_6__0 )?
-            int alt51=2;
-            int LA51_0 = input.LA(1);
-
-            if ( (LA51_0==28) ) {
-                alt51=1;
-            }
-            switch (alt51) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:6301:3: rule__ScriptTaskFlowElement__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_6__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
 
             }
 
@@ -19600,26 +19350,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:6309:1: rule__ScriptTaskFlowElement__Group__7 : rule__ScriptTaskFlowElement__Group__7__Impl rule__ScriptTaskFlowElement__Group__8 ;
-    public final void rule__ScriptTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__0"
+    // InternalTestgeneratorDSL.g:6315:1: rule__SequenceFlowElement__Group_4__0 : rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1 ;
+    public final void rule__SequenceFlowElement__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6313:1: ( rule__ScriptTaskFlowElement__Group__7__Impl rule__ScriptTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:6314:2: rule__ScriptTaskFlowElement__Group__7__Impl rule__ScriptTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:6319:1: ( rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1 )
+            // InternalTestgeneratorDSL.g:6320:2: rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1
             {
-            pushFollow(FOLLOW_26);
-            rule__ScriptTaskFlowElement__Group__7__Impl();
+            pushFollow(FOLLOW_38);
+            rule__SequenceFlowElement__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__8();
+            rule__SequenceFlowElement__Group_4__1();
 
             state._fsp--;
 
@@ -19638,46 +19388,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__7"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:6321:1: rule__ScriptTaskFlowElement__Group__7__Impl : ( ( rule__ScriptTaskFlowElement__Group_7__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:6327:1: rule__SequenceFlowElement__Group_4__0__Impl : ( 'with' ) ;
+    public final void rule__SequenceFlowElement__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6325:1: ( ( ( rule__ScriptTaskFlowElement__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:6326:1: ( ( rule__ScriptTaskFlowElement__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:6331:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:6332:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:6326:1: ( ( rule__ScriptTaskFlowElement__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:6327:2: ( rule__ScriptTaskFlowElement__Group_7__0 )?
+            // InternalTestgeneratorDSL.g:6332:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:6333:2: 'with'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:6328:2: ( rule__ScriptTaskFlowElement__Group_7__0 )?
-            int alt52=2;
-            int LA52_0 = input.LA(1);
-
-            if ( (LA52_0==43) ) {
-                alt52=1;
-            }
-            switch (alt52) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:6328:3: rule__ScriptTaskFlowElement__Group_7__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_7__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_7()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); 
 
             }
 
@@ -19696,21 +19425,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:6336:1: rule__ScriptTaskFlowElement__Group__8 : rule__ScriptTaskFlowElement__Group__8__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__1"
+    // InternalTestgeneratorDSL.g:6342:1: rule__SequenceFlowElement__Group_4__1 : rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2 ;
+    public final void rule__SequenceFlowElement__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6340:1: ( rule__ScriptTaskFlowElement__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:6341:2: rule__ScriptTaskFlowElement__Group__8__Impl
+            // InternalTestgeneratorDSL.g:6346:1: ( rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2 )
+            // InternalTestgeneratorDSL.g:6347:2: rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2
             {
+            pushFollow(FOLLOW_12);
+            rule__SequenceFlowElement__Group_4__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group__8__Impl();
+            rule__SequenceFlowElement__Group_4__2();
 
             state._fsp--;
 
@@ -19729,25 +19463,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__8"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:6347:1: rule__ScriptTaskFlowElement__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__ScriptTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:6354:1: rule__SequenceFlowElement__Group_4__1__Impl : ( 'expression' ) ;
+    public final void rule__SequenceFlowElement__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6351:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:6352:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:6358:1: ( ( 'expression' ) )
+            // InternalTestgeneratorDSL.g:6359:1: ( 'expression' )
             {
-            // InternalTestgeneratorDSL.g:6352:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:6353:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:6359:1: ( 'expression' )
+            // InternalTestgeneratorDSL.g:6360:2: 'expression'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); 
+            match(input,53,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); 
 
             }
 
@@ -19766,26 +19500,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group__8__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:6363:1: rule__ScriptTaskFlowElement__Group_4__0 : rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__0() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__2"
+    // InternalTestgeneratorDSL.g:6369:1: rule__SequenceFlowElement__Group_4__2 : rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3 ;
+    public final void rule__SequenceFlowElement__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6367:1: ( rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:6368:2: rule__ScriptTaskFlowElement__Group_4__0__Impl rule__ScriptTaskFlowElement__Group_4__1
+            // InternalTestgeneratorDSL.g:6373:1: ( rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3 )
+            // InternalTestgeneratorDSL.g:6374:2: rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3
             {
-            pushFollow(FOLLOW_19);
-            rule__ScriptTaskFlowElement__Group_4__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__SequenceFlowElement__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__1();
+            rule__SequenceFlowElement__Group_4__3();
 
             state._fsp--;
 
@@ -19804,25 +19538,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__0"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__2"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:6375:1: rule__ScriptTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:6381:1: rule__SequenceFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__SequenceFlowElement__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6379:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:6380:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:6385:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:6386:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:6380:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:6381:2: 'with'
+            // InternalTestgeneratorDSL.g:6386:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6387:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_4_0()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -19841,26 +19575,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__0__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:6390:1: rule__ScriptTaskFlowElement__Group_4__1 : rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__1() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__3"
+    // InternalTestgeneratorDSL.g:6396:1: rule__SequenceFlowElement__Group_4__3 : rule__SequenceFlowElement__Group_4__3__Impl ;
+    public final void rule__SequenceFlowElement__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6394:1: ( rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:6395:2: rule__ScriptTaskFlowElement__Group_4__1__Impl rule__ScriptTaskFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:6400:1: ( rule__SequenceFlowElement__Group_4__3__Impl )
+            // InternalTestgeneratorDSL.g:6401:2: rule__SequenceFlowElement__Group_4__3__Impl
             {
-            pushFollow(FOLLOW_20);
-            rule__ScriptTaskFlowElement__Group_4__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__2();
+            rule__SequenceFlowElement__Group_4__3__Impl();
 
             state._fsp--;
 
@@ -19879,25 +19608,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__1"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__3"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:6402:1: rule__ScriptTaskFlowElement__Group_4__1__Impl : ( 'hardcoded' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__SequenceFlowElement__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:6407:1: rule__SequenceFlowElement__Group_4__3__Impl : ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) ) ;
+    public final void rule__SequenceFlowElement__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6406:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:6407:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:6411:1: ( ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) ) )
+            // InternalTestgeneratorDSL.g:6412:1: ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) )
             {
-            // InternalTestgeneratorDSL.g:6407:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:6408:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:6412:1: ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:6413:2: ( rule__SequenceFlowElement__ExpressionAssignment_4_3 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedKeyword_4_1()); 
+             before(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); 
+            // InternalTestgeneratorDSL.g:6414:2: ( rule__SequenceFlowElement__ExpressionAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:6414:3: rule__SequenceFlowElement__ExpressionAssignment_4_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__SequenceFlowElement__ExpressionAssignment_4_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); 
 
             }
 
@@ -19916,26 +19655,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__1__Impl"
+    // $ANTLR end "rule__SequenceFlowElement__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:6417:1: rule__ScriptTaskFlowElement__Group_4__2 : rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__2() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group__0"
+    // InternalTestgeneratorDSL.g:6423:1: rule__FlowElementReference__Group__0 : rule__FlowElementReference__Group__0__Impl rule__FlowElementReference__Group__1 ;
+    public final void rule__FlowElementReference__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6421:1: ( rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:6422:2: rule__ScriptTaskFlowElement__Group_4__2__Impl rule__ScriptTaskFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:6427:1: ( rule__FlowElementReference__Group__0__Impl rule__FlowElementReference__Group__1 )
+            // InternalTestgeneratorDSL.g:6428:2: rule__FlowElementReference__Group__0__Impl rule__FlowElementReference__Group__1
             {
             pushFollow(FOLLOW_12);
-            rule__ScriptTaskFlowElement__Group_4__2__Impl();
+            rule__FlowElementReference__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__3();
+            rule__FlowElementReference__Group__1();
 
             state._fsp--;
 
@@ -19954,25 +19693,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__2"
+    // $ANTLR end "rule__FlowElementReference__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:6429:1: rule__ScriptTaskFlowElement__Group_4__2__Impl : ( 'inputs' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6435:1: rule__FlowElementReference__Group__0__Impl : ( ( rule__FlowElementReference__RefAssignment_0 ) ) ;
+    public final void rule__FlowElementReference__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6433:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:6434:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:6439:1: ( ( ( rule__FlowElementReference__RefAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:6440:1: ( ( rule__FlowElementReference__RefAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:6434:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:6435:2: 'inputs'
+            // InternalTestgeneratorDSL.g:6440:1: ( ( rule__FlowElementReference__RefAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:6441:2: ( rule__FlowElementReference__RefAssignment_0 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputsKeyword_4_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputsKeyword_4_2()); 
+             before(grammarAccess.getFlowElementReferenceAccess().getRefAssignment_0()); 
+            // InternalTestgeneratorDSL.g:6442:2: ( rule__FlowElementReference__RefAssignment_0 )
+            // InternalTestgeneratorDSL.g:6442:3: rule__FlowElementReference__RefAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__FlowElementReference__RefAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getFlowElementReferenceAccess().getRefAssignment_0()); 
 
             }
 
@@ -19991,26 +19740,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__2__Impl"
+    // $ANTLR end "rule__FlowElementReference__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:6444:1: rule__ScriptTaskFlowElement__Group_4__3 : rule__ScriptTaskFlowElement__Group_4__3__Impl rule__ScriptTaskFlowElement__Group_4__4 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__3() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group__1"
+    // InternalTestgeneratorDSL.g:6450:1: rule__FlowElementReference__Group__1 : rule__FlowElementReference__Group__1__Impl ;
+    public final void rule__FlowElementReference__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6448:1: ( rule__ScriptTaskFlowElement__Group_4__3__Impl rule__ScriptTaskFlowElement__Group_4__4 )
-            // InternalTestgeneratorDSL.g:6449:2: rule__ScriptTaskFlowElement__Group_4__3__Impl rule__ScriptTaskFlowElement__Group_4__4
+            // InternalTestgeneratorDSL.g:6454:1: ( rule__FlowElementReference__Group__1__Impl )
+            // InternalTestgeneratorDSL.g:6455:2: rule__FlowElementReference__Group__1__Impl
             {
-            pushFollow(FOLLOW_13);
-            rule__ScriptTaskFlowElement__Group_4__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__4();
+            rule__FlowElementReference__Group__1__Impl();
 
             state._fsp--;
 
@@ -20029,25 +19773,50 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__3"
+    // $ANTLR end "rule__FlowElementReference__Group__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:6456:1: rule__ScriptTaskFlowElement__Group_4__3__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:6461:1: rule__FlowElementReference__Group__1__Impl : ( ( rule__FlowElementReference__Group_1__0 )? ) ;
+    public final void rule__FlowElementReference__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6460:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:6461:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6465:1: ( ( ( rule__FlowElementReference__Group_1__0 )? ) )
+            // InternalTestgeneratorDSL.g:6466:1: ( ( rule__FlowElementReference__Group_1__0 )? )
             {
-            // InternalTestgeneratorDSL.g:6461:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:6462:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:6466:1: ( ( rule__FlowElementReference__Group_1__0 )? )
+            // InternalTestgeneratorDSL.g:6467:2: ( rule__FlowElementReference__Group_1__0 )?
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3()); 
+             before(grammarAccess.getFlowElementReferenceAccess().getGroup_1()); 
+            // InternalTestgeneratorDSL.g:6468:2: ( rule__FlowElementReference__Group_1__0 )?
+            int alt40=2;
+            int LA40_0 = input.LA(1);
+
+            if ( (LA40_0==RULE_ASSOCIATION) ) {
+                int LA40_1 = input.LA(2);
+
+                if ( ((LA40_1>=24 && LA40_1<=27)) ) {
+                    alt40=1;
+                }
+            }
+            switch (alt40) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:6468:3: rule__FlowElementReference__Group_1__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__FlowElementReference__Group_1__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getFlowElementReferenceAccess().getGroup_1()); 
 
             }
 
@@ -20066,26 +19835,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__3__Impl"
+    // $ANTLR end "rule__FlowElementReference__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__4"
-    // InternalTestgeneratorDSL.g:6471:1: rule__ScriptTaskFlowElement__Group_4__4 : rule__ScriptTaskFlowElement__Group_4__4__Impl rule__ScriptTaskFlowElement__Group_4__5 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__4() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group_1__0"
+    // InternalTestgeneratorDSL.g:6477:1: rule__FlowElementReference__Group_1__0 : rule__FlowElementReference__Group_1__0__Impl rule__FlowElementReference__Group_1__1 ;
+    public final void rule__FlowElementReference__Group_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6475:1: ( rule__ScriptTaskFlowElement__Group_4__4__Impl rule__ScriptTaskFlowElement__Group_4__5 )
-            // InternalTestgeneratorDSL.g:6476:2: rule__ScriptTaskFlowElement__Group_4__4__Impl rule__ScriptTaskFlowElement__Group_4__5
+            // InternalTestgeneratorDSL.g:6481:1: ( rule__FlowElementReference__Group_1__0__Impl rule__FlowElementReference__Group_1__1 )
+            // InternalTestgeneratorDSL.g:6482:2: rule__FlowElementReference__Group_1__0__Impl rule__FlowElementReference__Group_1__1
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_4__4__Impl();
+            pushFollow(FOLLOW_39);
+            rule__FlowElementReference__Group_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__5();
+            rule__FlowElementReference__Group_1__1();
 
             state._fsp--;
 
@@ -20104,25 +19873,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__4"
+    // $ANTLR end "rule__FlowElementReference__Group_1__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__4__Impl"
-    // InternalTestgeneratorDSL.g:6483:1: rule__ScriptTaskFlowElement__Group_4__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group_1__0__Impl"
+    // InternalTestgeneratorDSL.g:6489:1: rule__FlowElementReference__Group_1__0__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__FlowElementReference__Group_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6487:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:6488:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:6493:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:6494:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:6488:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:6489:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:6494:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6495:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4()); 
+             before(grammarAccess.getFlowElementReferenceAccess().getASSOCIATIONTerminalRuleCall_1_0()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getFlowElementReferenceAccess().getASSOCIATIONTerminalRuleCall_1_0()); 
 
             }
 
@@ -20141,26 +19910,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__4__Impl"
+    // $ANTLR end "rule__FlowElementReference__Group_1__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__5"
-    // InternalTestgeneratorDSL.g:6498:1: rule__ScriptTaskFlowElement__Group_4__5 : rule__ScriptTaskFlowElement__Group_4__5__Impl rule__ScriptTaskFlowElement__Group_4__6 ;
-    public final void rule__ScriptTaskFlowElement__Group_4__5() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group_1__1"
+    // InternalTestgeneratorDSL.g:6504:1: rule__FlowElementReference__Group_1__1 : rule__FlowElementReference__Group_1__1__Impl ;
+    public final void rule__FlowElementReference__Group_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6502:1: ( rule__ScriptTaskFlowElement__Group_4__5__Impl rule__ScriptTaskFlowElement__Group_4__6 )
-            // InternalTestgeneratorDSL.g:6503:2: rule__ScriptTaskFlowElement__Group_4__5__Impl rule__ScriptTaskFlowElement__Group_4__6
+            // InternalTestgeneratorDSL.g:6508:1: ( rule__FlowElementReference__Group_1__1__Impl )
+            // InternalTestgeneratorDSL.g:6509:2: rule__FlowElementReference__Group_1__1__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_4__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__6();
+            rule__FlowElementReference__Group_1__1__Impl();
 
             state._fsp--;
 
@@ -20179,46 +19943,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__5"
+    // $ANTLR end "rule__FlowElementReference__Group_1__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__5__Impl"
-    // InternalTestgeneratorDSL.g:6510:1: rule__ScriptTaskFlowElement__Group_4__5__Impl : ( ( rule__ScriptTaskFlowElement__Group_4_5__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__Group_1__1__Impl"
+    // InternalTestgeneratorDSL.g:6515:1: rule__FlowElementReference__Group_1__1__Impl : ( ( rule__FlowElementReference__FlagAssignment_1_1 ) ) ;
+    public final void rule__FlowElementReference__Group_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6514:1: ( ( ( rule__ScriptTaskFlowElement__Group_4_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:6515:1: ( ( rule__ScriptTaskFlowElement__Group_4_5__0 )? )
+            // InternalTestgeneratorDSL.g:6519:1: ( ( ( rule__FlowElementReference__FlagAssignment_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:6520:1: ( ( rule__FlowElementReference__FlagAssignment_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6515:1: ( ( rule__ScriptTaskFlowElement__Group_4_5__0 )? )
-            // InternalTestgeneratorDSL.g:6516:2: ( rule__ScriptTaskFlowElement__Group_4_5__0 )?
+            // InternalTestgeneratorDSL.g:6520:1: ( ( rule__FlowElementReference__FlagAssignment_1_1 ) )
+            // InternalTestgeneratorDSL.g:6521:2: ( rule__FlowElementReference__FlagAssignment_1_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5()); 
-            // InternalTestgeneratorDSL.g:6517:2: ( rule__ScriptTaskFlowElement__Group_4_5__0 )?
-            int alt53=2;
-            int LA53_0 = input.LA(1);
-
-            if ( (LA53_0==RULE_ID) ) {
-                alt53=1;
-            }
-            switch (alt53) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:6517:3: rule__ScriptTaskFlowElement__Group_4_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_4_5__0();
-
-                    state._fsp--;
+             before(grammarAccess.getFlowElementReferenceAccess().getFlagAssignment_1_1()); 
+            // InternalTestgeneratorDSL.g:6522:2: ( rule__FlowElementReference__FlagAssignment_1_1 )
+            // InternalTestgeneratorDSL.g:6522:3: rule__FlowElementReference__FlagAssignment_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__FlowElementReference__FlagAssignment_1_1();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5()); 
+             after(grammarAccess.getFlowElementReferenceAccess().getFlagAssignment_1_1()); 
 
             }
 
@@ -20237,21 +19990,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__5__Impl"
+    // $ANTLR end "rule__FlowElementReference__Group_1__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__6"
-    // InternalTestgeneratorDSL.g:6525:1: rule__ScriptTaskFlowElement__Group_4__6 : rule__ScriptTaskFlowElement__Group_4__6__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_4__6() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__0"
+    // InternalTestgeneratorDSL.g:6531:1: rule__ExternalTopic__Group__0 : rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1 ;
+    public final void rule__ExternalTopic__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6529:1: ( rule__ScriptTaskFlowElement__Group_4__6__Impl )
-            // InternalTestgeneratorDSL.g:6530:2: rule__ScriptTaskFlowElement__Group_4__6__Impl
+            // InternalTestgeneratorDSL.g:6535:1: ( rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1 )
+            // InternalTestgeneratorDSL.g:6536:2: rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1
             {
+            pushFollow(FOLLOW_4);
+            rule__ExternalTopic__Group__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4__6__Impl();
+            rule__ExternalTopic__Group__1();
 
             state._fsp--;
 
@@ -20270,25 +20028,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__6"
+    // $ANTLR end "rule__ExternalTopic__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4__6__Impl"
-    // InternalTestgeneratorDSL.g:6536:1: rule__ScriptTaskFlowElement__Group_4__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6543:1: rule__ExternalTopic__Group__0__Impl : ( 'ExternalTopic' ) ;
+    public final void rule__ExternalTopic__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6540:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:6541:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:6547:1: ( ( 'ExternalTopic' ) )
+            // InternalTestgeneratorDSL.g:6548:1: ( 'ExternalTopic' )
             {
-            // InternalTestgeneratorDSL.g:6541:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:6542:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:6548:1: ( 'ExternalTopic' )
+            // InternalTestgeneratorDSL.g:6549:2: 'ExternalTopic'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6()); 
+             before(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); 
+            match(input,54,FOLLOW_2); 
+             after(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); 
 
             }
 
@@ -20307,26 +20065,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4__6__Impl"
+    // $ANTLR end "rule__ExternalTopic__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5__0"
-    // InternalTestgeneratorDSL.g:6552:1: rule__ScriptTaskFlowElement__Group_4_5__0 : rule__ScriptTaskFlowElement__Group_4_5__0__Impl rule__ScriptTaskFlowElement__Group_4_5__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__1"
+    // InternalTestgeneratorDSL.g:6558:1: rule__ExternalTopic__Group__1 : rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2 ;
+    public final void rule__ExternalTopic__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6556:1: ( rule__ScriptTaskFlowElement__Group_4_5__0__Impl rule__ScriptTaskFlowElement__Group_4_5__1 )
-            // InternalTestgeneratorDSL.g:6557:2: rule__ScriptTaskFlowElement__Group_4_5__0__Impl rule__ScriptTaskFlowElement__Group_4_5__1
+            // InternalTestgeneratorDSL.g:6562:1: ( rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2 )
+            // InternalTestgeneratorDSL.g:6563:2: rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2
             {
-            pushFollow(FOLLOW_15);
-            rule__ScriptTaskFlowElement__Group_4_5__0__Impl();
+            pushFollow(FOLLOW_22);
+            rule__ExternalTopic__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4_5__1();
+            rule__ExternalTopic__Group__2();
 
             state._fsp--;
 
@@ -20345,35 +20103,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5__0"
+    // $ANTLR end "rule__ExternalTopic__Group__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5__0__Impl"
-    // InternalTestgeneratorDSL.g:6564:1: rule__ScriptTaskFlowElement__Group_4_5__0__Impl : ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:6570:1: rule__ExternalTopic__Group__1__Impl : ( ( rule__ExternalTopic__NameAssignment_1 ) ) ;
+    public final void rule__ExternalTopic__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6568:1: ( ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:6569:1: ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
+            // InternalTestgeneratorDSL.g:6574:1: ( ( ( rule__ExternalTopic__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:6575:1: ( ( rule__ExternalTopic__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6569:1: ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 ) )
-            // InternalTestgeneratorDSL.g:6570:2: ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
+            // InternalTestgeneratorDSL.g:6575:1: ( ( rule__ExternalTopic__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:6576:2: ( rule__ExternalTopic__NameAssignment_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
-            // InternalTestgeneratorDSL.g:6571:2: ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 )
-            // InternalTestgeneratorDSL.g:6571:3: rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0
+             before(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:6577:2: ( rule__ExternalTopic__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:6577:3: rule__ExternalTopic__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0();
+            rule__ExternalTopic__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_0()); 
+             after(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); 
 
             }
 
@@ -20392,21 +20150,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5__0__Impl"
+    // $ANTLR end "rule__ExternalTopic__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5__1"
-    // InternalTestgeneratorDSL.g:6579:1: rule__ScriptTaskFlowElement__Group_4_5__1 : rule__ScriptTaskFlowElement__Group_4_5__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__2"
+    // InternalTestgeneratorDSL.g:6585:1: rule__ExternalTopic__Group__2 : rule__ExternalTopic__Group__2__Impl ;
+    public final void rule__ExternalTopic__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6583:1: ( rule__ScriptTaskFlowElement__Group_4_5__1__Impl )
-            // InternalTestgeneratorDSL.g:6584:2: rule__ScriptTaskFlowElement__Group_4_5__1__Impl
+            // InternalTestgeneratorDSL.g:6589:1: ( rule__ExternalTopic__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:6590:2: rule__ExternalTopic__Group__2__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4_5__1__Impl();
+            rule__ExternalTopic__Group__2__Impl();
 
             state._fsp--;
 
@@ -20425,53 +20183,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5__1"
+    // $ANTLR end "rule__ExternalTopic__Group__2"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5__1__Impl"
-    // InternalTestgeneratorDSL.g:6590:1: rule__ScriptTaskFlowElement__Group_4_5__1__Impl : ( ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )* ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalTopic__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:6596:1: rule__ExternalTopic__Group__2__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__ExternalTopic__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6594:1: ( ( ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:6595:1: ( ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:6600:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:6601:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:6595:1: ( ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:6596:2: ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )*
+            // InternalTestgeneratorDSL.g:6601:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:6602:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5_1()); 
-            // InternalTestgeneratorDSL.g:6597:2: ( rule__ScriptTaskFlowElement__Group_4_5_1__0 )*
-            loop54:
-            do {
-                int alt54=2;
-                int LA54_0 = input.LA(1);
-
-                if ( (LA54_0==RULE_SEPARATOR) ) {
-                    alt54=1;
-                }
-
-
-                switch (alt54) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:6597:3: rule__ScriptTaskFlowElement__Group_4_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ScriptTaskFlowElement__Group_4_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop54;
-                }
-            } while (true);
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_4_5_1()); 
+             before(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); 
 
             }
 
@@ -20490,26 +20220,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5__1__Impl"
+    // $ANTLR end "rule__ExternalTopic__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5_1__0"
-    // InternalTestgeneratorDSL.g:6606:1: rule__ScriptTaskFlowElement__Group_4_5_1__0 : rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl rule__ScriptTaskFlowElement__Group_4_5_1__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__0"
+    // InternalTestgeneratorDSL.g:6612:1: rule__StringVariable__Group__0 : rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1 ;
+    public final void rule__StringVariable__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6610:1: ( rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl rule__ScriptTaskFlowElement__Group_4_5_1__1 )
-            // InternalTestgeneratorDSL.g:6611:2: rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl rule__ScriptTaskFlowElement__Group_4_5_1__1
+            // InternalTestgeneratorDSL.g:6616:1: ( rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1 )
+            // InternalTestgeneratorDSL.g:6617:2: rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1
             {
             pushFollow(FOLLOW_4);
-            rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl();
+            rule__StringVariable__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4_5_1__1();
+            rule__StringVariable__Group__1();
 
             state._fsp--;
 
@@ -20528,25 +20258,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5_1__0"
+    // $ANTLR end "rule__StringVariable__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:6618:1: rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6624:1: rule__StringVariable__Group__0__Impl : ( 'String' ) ;
+    public final void rule__StringVariable__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6622:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:6623:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:6628:1: ( ( 'String' ) )
+            // InternalTestgeneratorDSL.g:6629:1: ( 'String' )
             {
-            // InternalTestgeneratorDSL.g:6623:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:6624:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:6629:1: ( 'String' )
+            // InternalTestgeneratorDSL.g:6630:2: 'String'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0()); 
+             before(grammarAccess.getStringVariableAccess().getStringKeyword_0()); 
+            match(input,55,FOLLOW_2); 
+             after(grammarAccess.getStringVariableAccess().getStringKeyword_0()); 
 
             }
 
@@ -20565,21 +20295,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5_1__0__Impl"
+    // $ANTLR end "rule__StringVariable__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5_1__1"
-    // InternalTestgeneratorDSL.g:6633:1: rule__ScriptTaskFlowElement__Group_4_5_1__1 : rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__1"
+    // InternalTestgeneratorDSL.g:6639:1: rule__StringVariable__Group__1 : rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2 ;
+    public final void rule__StringVariable__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6637:1: ( rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:6638:2: rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:6643:1: ( rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2 )
+            // InternalTestgeneratorDSL.g:6644:2: rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2
             {
+            pushFollow(FOLLOW_5);
+            rule__StringVariable__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl();
+            rule__StringVariable__Group__2();
 
             state._fsp--;
 
@@ -20598,35 +20333,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5_1__1"
+    // $ANTLR end "rule__StringVariable__Group__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:6644:1: rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl : ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:6651:1: rule__StringVariable__Group__1__Impl : ( ( rule__StringVariable__NameAssignment_1 ) ) ;
+    public final void rule__StringVariable__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6648:1: ( ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:6649:1: ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:6655:1: ( ( ( rule__StringVariable__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:6656:1: ( ( rule__StringVariable__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6649:1: ( ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:6650:2: ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
+            // InternalTestgeneratorDSL.g:6656:1: ( ( rule__StringVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:6657:2: ( rule__StringVariable__NameAssignment_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
-            // InternalTestgeneratorDSL.g:6651:2: ( rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 )
-            // InternalTestgeneratorDSL.g:6651:3: rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1
+             before(grammarAccess.getStringVariableAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:6658:2: ( rule__StringVariable__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:6658:3: rule__StringVariable__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1();
+            rule__StringVariable__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsAssignment_4_5_1_1()); 
+             after(grammarAccess.getStringVariableAccess().getNameAssignment_1()); 
 
             }
 
@@ -20645,26 +20380,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_4_5_1__1__Impl"
+    // $ANTLR end "rule__StringVariable__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__0"
-    // InternalTestgeneratorDSL.g:6660:1: rule__ScriptTaskFlowElement__Group_5__0 : rule__ScriptTaskFlowElement__Group_5__0__Impl rule__ScriptTaskFlowElement__Group_5__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_5__0() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__2"
+    // InternalTestgeneratorDSL.g:6666:1: rule__StringVariable__Group__2 : rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3 ;
+    public final void rule__StringVariable__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6664:1: ( rule__ScriptTaskFlowElement__Group_5__0__Impl rule__ScriptTaskFlowElement__Group_5__1 )
-            // InternalTestgeneratorDSL.g:6665:2: rule__ScriptTaskFlowElement__Group_5__0__Impl rule__ScriptTaskFlowElement__Group_5__1
+            // InternalTestgeneratorDSL.g:6670:1: ( rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3 )
+            // InternalTestgeneratorDSL.g:6671:2: rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3
             {
-            pushFollow(FOLLOW_27);
-            rule__ScriptTaskFlowElement__Group_5__0__Impl();
+            pushFollow(FOLLOW_40);
+            rule__StringVariable__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__1();
+            rule__StringVariable__Group__3();
 
             state._fsp--;
 
@@ -20683,25 +20418,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__0"
+    // $ANTLR end "rule__StringVariable__Group__2"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:6672:1: rule__ScriptTaskFlowElement__Group_5__0__Impl : ( 'with' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:6678:1: rule__StringVariable__Group__2__Impl : ( 'with' ) ;
+    public final void rule__StringVariable__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6676:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:6677:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:6682:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:6683:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:6677:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:6678:2: 'with'
+            // InternalTestgeneratorDSL.g:6683:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:6684:2: 'with'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_5_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_5_0()); 
+             before(grammarAccess.getStringVariableAccess().getWithKeyword_2()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getStringVariableAccess().getWithKeyword_2()); 
 
             }
 
@@ -20720,26 +20455,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__0__Impl"
+    // $ANTLR end "rule__StringVariable__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__1"
-    // InternalTestgeneratorDSL.g:6687:1: rule__ScriptTaskFlowElement__Group_5__1 : rule__ScriptTaskFlowElement__Group_5__1__Impl rule__ScriptTaskFlowElement__Group_5__2 ;
-    public final void rule__ScriptTaskFlowElement__Group_5__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__3"
+    // InternalTestgeneratorDSL.g:6693:1: rule__StringVariable__Group__3 : rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4 ;
+    public final void rule__StringVariable__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6691:1: ( rule__ScriptTaskFlowElement__Group_5__1__Impl rule__ScriptTaskFlowElement__Group_5__2 )
-            // InternalTestgeneratorDSL.g:6692:2: rule__ScriptTaskFlowElement__Group_5__1__Impl rule__ScriptTaskFlowElement__Group_5__2
+            // InternalTestgeneratorDSL.g:6697:1: ( rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4 )
+            // InternalTestgeneratorDSL.g:6698:2: rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4
             {
             pushFollow(FOLLOW_12);
-            rule__ScriptTaskFlowElement__Group_5__1__Impl();
+            rule__StringVariable__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__2();
+            rule__StringVariable__Group__4();
 
             state._fsp--;
 
@@ -20758,25 +20493,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__1"
+    // $ANTLR end "rule__StringVariable__Group__3"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:6699:1: rule__ScriptTaskFlowElement__Group_5__1__Impl : ( 'inputVariables' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:6705:1: rule__StringVariable__Group__3__Impl : ( 'proposals' ) ;
+    public final void rule__StringVariable__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6703:1: ( ( 'inputVariables' ) )
-            // InternalTestgeneratorDSL.g:6704:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:6709:1: ( ( 'proposals' ) )
+            // InternalTestgeneratorDSL.g:6710:1: ( 'proposals' )
             {
-            // InternalTestgeneratorDSL.g:6704:1: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:6705:2: 'inputVariables'
+            // InternalTestgeneratorDSL.g:6710:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:6711:2: 'proposals'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
-            match(input,41,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesKeyword_5_1()); 
+             before(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); 
+            match(input,56,FOLLOW_2); 
+             after(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); 
 
             }
 
@@ -20795,26 +20530,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__1__Impl"
+    // $ANTLR end "rule__StringVariable__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__2"
-    // InternalTestgeneratorDSL.g:6714:1: rule__ScriptTaskFlowElement__Group_5__2 : rule__ScriptTaskFlowElement__Group_5__2__Impl rule__ScriptTaskFlowElement__Group_5__3 ;
-    public final void rule__ScriptTaskFlowElement__Group_5__2() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__4"
+    // InternalTestgeneratorDSL.g:6720:1: rule__StringVariable__Group__4 : rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5 ;
+    public final void rule__StringVariable__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6718:1: ( rule__ScriptTaskFlowElement__Group_5__2__Impl rule__ScriptTaskFlowElement__Group_5__3 )
-            // InternalTestgeneratorDSL.g:6719:2: rule__ScriptTaskFlowElement__Group_5__2__Impl rule__ScriptTaskFlowElement__Group_5__3
+            // InternalTestgeneratorDSL.g:6724:1: ( rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5 )
+            // InternalTestgeneratorDSL.g:6725:2: rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5
             {
             pushFollow(FOLLOW_13);
-            rule__ScriptTaskFlowElement__Group_5__2__Impl();
+            rule__StringVariable__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__3();
+            rule__StringVariable__Group__5();
 
             state._fsp--;
 
@@ -20833,25 +20568,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__2"
+    // $ANTLR end "rule__StringVariable__Group__4"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__2__Impl"
-    // InternalTestgeneratorDSL.g:6726:1: rule__ScriptTaskFlowElement__Group_5__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:6732:1: rule__StringVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__StringVariable__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6730:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:6731:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6736:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:6737:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:6731:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:6732:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:6737:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:6738:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             before(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2()); 
+             after(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
 
             }
 
@@ -20870,26 +20605,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__2__Impl"
+    // $ANTLR end "rule__StringVariable__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__3"
-    // InternalTestgeneratorDSL.g:6741:1: rule__ScriptTaskFlowElement__Group_5__3 : rule__ScriptTaskFlowElement__Group_5__3__Impl rule__ScriptTaskFlowElement__Group_5__4 ;
-    public final void rule__ScriptTaskFlowElement__Group_5__3() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__5"
+    // InternalTestgeneratorDSL.g:6747:1: rule__StringVariable__Group__5 : rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6 ;
+    public final void rule__StringVariable__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6745:1: ( rule__ScriptTaskFlowElement__Group_5__3__Impl rule__ScriptTaskFlowElement__Group_5__4 )
-            // InternalTestgeneratorDSL.g:6746:2: rule__ScriptTaskFlowElement__Group_5__3__Impl rule__ScriptTaskFlowElement__Group_5__4
+            // InternalTestgeneratorDSL.g:6751:1: ( rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6 )
+            // InternalTestgeneratorDSL.g:6752:2: rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_5__3__Impl();
+            pushFollow(FOLLOW_14);
+            rule__StringVariable__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__4();
+            rule__StringVariable__Group__6();
 
             state._fsp--;
 
@@ -20908,25 +20643,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__3"
+    // $ANTLR end "rule__StringVariable__Group__5"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__3__Impl"
-    // InternalTestgeneratorDSL.g:6753:1: rule__ScriptTaskFlowElement__Group_5__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:6759:1: rule__StringVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__StringVariable__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6757:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:6758:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:6763:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:6764:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:6758:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:6759:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:6764:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:6765:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
+             before(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
             match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3()); 
+             after(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
 
             }
 
@@ -20945,26 +20680,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__3__Impl"
+    // $ANTLR end "rule__StringVariable__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__4"
-    // InternalTestgeneratorDSL.g:6768:1: rule__ScriptTaskFlowElement__Group_5__4 : rule__ScriptTaskFlowElement__Group_5__4__Impl rule__ScriptTaskFlowElement__Group_5__5 ;
-    public final void rule__ScriptTaskFlowElement__Group_5__4() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__6"
+    // InternalTestgeneratorDSL.g:6774:1: rule__StringVariable__Group__6 : rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7 ;
+    public final void rule__StringVariable__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6772:1: ( rule__ScriptTaskFlowElement__Group_5__4__Impl rule__ScriptTaskFlowElement__Group_5__5 )
-            // InternalTestgeneratorDSL.g:6773:2: rule__ScriptTaskFlowElement__Group_5__4__Impl rule__ScriptTaskFlowElement__Group_5__5
+            // InternalTestgeneratorDSL.g:6778:1: ( rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7 )
+            // InternalTestgeneratorDSL.g:6779:2: rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_5__4__Impl();
+            pushFollow(FOLLOW_14);
+            rule__StringVariable__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__5();
+            rule__StringVariable__Group__7();
 
             state._fsp--;
 
@@ -20983,36 +20718,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__4"
+    // $ANTLR end "rule__StringVariable__Group__6"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__4__Impl"
-    // InternalTestgeneratorDSL.g:6780:1: rule__ScriptTaskFlowElement__Group_5__4__Impl : ( ( rule__ScriptTaskFlowElement__Group_5_4__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:6786:1: rule__StringVariable__Group__6__Impl : ( ( rule__StringVariable__Group_6__0 )? ) ;
+    public final void rule__StringVariable__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6784:1: ( ( ( rule__ScriptTaskFlowElement__Group_5_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:6785:1: ( ( rule__ScriptTaskFlowElement__Group_5_4__0 )? )
+            // InternalTestgeneratorDSL.g:6790:1: ( ( ( rule__StringVariable__Group_6__0 )? ) )
+            // InternalTestgeneratorDSL.g:6791:1: ( ( rule__StringVariable__Group_6__0 )? )
             {
-            // InternalTestgeneratorDSL.g:6785:1: ( ( rule__ScriptTaskFlowElement__Group_5_4__0 )? )
-            // InternalTestgeneratorDSL.g:6786:2: ( rule__ScriptTaskFlowElement__Group_5_4__0 )?
+            // InternalTestgeneratorDSL.g:6791:1: ( ( rule__StringVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:6792:2: ( rule__StringVariable__Group_6__0 )?
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4()); 
-            // InternalTestgeneratorDSL.g:6787:2: ( rule__ScriptTaskFlowElement__Group_5_4__0 )?
-            int alt55=2;
-            int LA55_0 = input.LA(1);
+             before(grammarAccess.getStringVariableAccess().getGroup_6()); 
+            // InternalTestgeneratorDSL.g:6793:2: ( rule__StringVariable__Group_6__0 )?
+            int alt41=2;
+            int LA41_0 = input.LA(1);
 
-            if ( (LA55_0==RULE_ID) ) {
-                alt55=1;
+            if ( (LA41_0==RULE_STRING) ) {
+                alt41=1;
             }
-            switch (alt55) {
+            switch (alt41) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:6787:3: rule__ScriptTaskFlowElement__Group_5_4__0
+                    // InternalTestgeneratorDSL.g:6793:3: rule__StringVariable__Group_6__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_5_4__0();
+                    rule__StringVariable__Group_6__0();
 
                     state._fsp--;
 
@@ -21022,7 +20757,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4()); 
+             after(grammarAccess.getStringVariableAccess().getGroup_6()); 
 
             }
 
@@ -21041,21 +20776,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__4__Impl"
+    // $ANTLR end "rule__StringVariable__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__5"
-    // InternalTestgeneratorDSL.g:6795:1: rule__ScriptTaskFlowElement__Group_5__5 : rule__ScriptTaskFlowElement__Group_5__5__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_5__5() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__7"
+    // InternalTestgeneratorDSL.g:6801:1: rule__StringVariable__Group__7 : rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8 ;
+    public final void rule__StringVariable__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6799:1: ( rule__ScriptTaskFlowElement__Group_5__5__Impl )
-            // InternalTestgeneratorDSL.g:6800:2: rule__ScriptTaskFlowElement__Group_5__5__Impl
+            // InternalTestgeneratorDSL.g:6805:1: ( rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8 )
+            // InternalTestgeneratorDSL.g:6806:2: rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8
             {
+            pushFollow(FOLLOW_22);
+            rule__StringVariable__Group__7__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5__5__Impl();
+            rule__StringVariable__Group__8();
 
             state._fsp--;
 
@@ -21074,25 +20814,95 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__5"
+    // $ANTLR end "rule__StringVariable__Group__7"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5__5__Impl"
-    // InternalTestgeneratorDSL.g:6806:1: rule__ScriptTaskFlowElement__Group_5__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:6813:1: rule__StringVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__StringVariable__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6810:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:6811:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:6817:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:6818:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:6811:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:6812:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:6818:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:6819:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
+             before(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
             match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5()); 
+             after(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+
+            }
+
+
+            }
+
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__StringVariable__Group__7__Impl"
+
+
+    // $ANTLR start "rule__StringVariable__Group__8"
+    // InternalTestgeneratorDSL.g:6828:1: rule__StringVariable__Group__8 : rule__StringVariable__Group__8__Impl ;
+    public final void rule__StringVariable__Group__8() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:6832:1: ( rule__StringVariable__Group__8__Impl )
+            // InternalTestgeneratorDSL.g:6833:2: rule__StringVariable__Group__8__Impl
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariable__Group__8__Impl();
+
+            state._fsp--;
+
+
+            }
+
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__StringVariable__Group__8"
+
+
+    // $ANTLR start "rule__StringVariable__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:6839:1: rule__StringVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__StringVariable__Group__8__Impl() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:6843:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:6844:1: ( RULE_DECLARATION_FINISHED )
+            {
+            // InternalTestgeneratorDSL.g:6844:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:6845:2: RULE_DECLARATION_FINISHED
+            {
+             before(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
 
             }
 
@@ -21111,26 +20921,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5__5__Impl"
+    // $ANTLR end "rule__StringVariable__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4__0"
-    // InternalTestgeneratorDSL.g:6822:1: rule__ScriptTaskFlowElement__Group_5_4__0 : rule__ScriptTaskFlowElement__Group_5_4__0__Impl rule__ScriptTaskFlowElement__Group_5_4__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4__0() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6__0"
+    // InternalTestgeneratorDSL.g:6855:1: rule__StringVariable__Group_6__0 : rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1 ;
+    public final void rule__StringVariable__Group_6__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6826:1: ( rule__ScriptTaskFlowElement__Group_5_4__0__Impl rule__ScriptTaskFlowElement__Group_5_4__1 )
-            // InternalTestgeneratorDSL.g:6827:2: rule__ScriptTaskFlowElement__Group_5_4__0__Impl rule__ScriptTaskFlowElement__Group_5_4__1
+            // InternalTestgeneratorDSL.g:6859:1: ( rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1 )
+            // InternalTestgeneratorDSL.g:6860:2: rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1
             {
             pushFollow(FOLLOW_15);
-            rule__ScriptTaskFlowElement__Group_5_4__0__Impl();
+            rule__StringVariable__Group_6__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5_4__1();
+            rule__StringVariable__Group_6__1();
 
             state._fsp--;
 
@@ -21149,35 +20959,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4__0"
+    // $ANTLR end "rule__StringVariable__Group_6__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4__0__Impl"
-    // InternalTestgeneratorDSL.g:6834:1: rule__ScriptTaskFlowElement__Group_5_4__0__Impl : ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6__0__Impl"
+    // InternalTestgeneratorDSL.g:6867:1: rule__StringVariable__Group_6__0__Impl : ( ( rule__StringVariable__ProposalsAssignment_6_0 ) ) ;
+    public final void rule__StringVariable__Group_6__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6838:1: ( ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:6839:1: ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
+            // InternalTestgeneratorDSL.g:6871:1: ( ( ( rule__StringVariable__ProposalsAssignment_6_0 ) ) )
+            // InternalTestgeneratorDSL.g:6872:1: ( ( rule__StringVariable__ProposalsAssignment_6_0 ) )
             {
-            // InternalTestgeneratorDSL.g:6839:1: ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 ) )
-            // InternalTestgeneratorDSL.g:6840:2: ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 )
+            // InternalTestgeneratorDSL.g:6872:1: ( ( rule__StringVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:6873:2: ( rule__StringVariable__ProposalsAssignment_6_0 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
-            // InternalTestgeneratorDSL.g:6841:2: ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 )
-            // InternalTestgeneratorDSL.g:6841:3: rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0
+             before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); 
+            // InternalTestgeneratorDSL.g:6874:2: ( rule__StringVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:6874:3: rule__StringVariable__ProposalsAssignment_6_0
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0();
+            rule__StringVariable__ProposalsAssignment_6_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_0()); 
+             after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); 
 
             }
 
@@ -21196,21 +21006,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4__0__Impl"
+    // $ANTLR end "rule__StringVariable__Group_6__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4__1"
-    // InternalTestgeneratorDSL.g:6849:1: rule__ScriptTaskFlowElement__Group_5_4__1 : rule__ScriptTaskFlowElement__Group_5_4__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6__1"
+    // InternalTestgeneratorDSL.g:6882:1: rule__StringVariable__Group_6__1 : rule__StringVariable__Group_6__1__Impl ;
+    public final void rule__StringVariable__Group_6__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6853:1: ( rule__ScriptTaskFlowElement__Group_5_4__1__Impl )
-            // InternalTestgeneratorDSL.g:6854:2: rule__ScriptTaskFlowElement__Group_5_4__1__Impl
+            // InternalTestgeneratorDSL.g:6886:1: ( rule__StringVariable__Group_6__1__Impl )
+            // InternalTestgeneratorDSL.g:6887:2: rule__StringVariable__Group_6__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5_4__1__Impl();
+            rule__StringVariable__Group_6__1__Impl();
 
             state._fsp--;
 
@@ -21229,40 +21039,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4__1"
+    // $ANTLR end "rule__StringVariable__Group_6__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4__1__Impl"
-    // InternalTestgeneratorDSL.g:6860:1: rule__ScriptTaskFlowElement__Group_5_4__1__Impl : ( ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )* ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6__1__Impl"
+    // InternalTestgeneratorDSL.g:6893:1: rule__StringVariable__Group_6__1__Impl : ( ( rule__StringVariable__Group_6_1__0 )* ) ;
+    public final void rule__StringVariable__Group_6__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6864:1: ( ( ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:6865:1: ( ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:6897:1: ( ( ( rule__StringVariable__Group_6_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:6898:1: ( ( rule__StringVariable__Group_6_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:6865:1: ( ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:6866:2: ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )*
+            // InternalTestgeneratorDSL.g:6898:1: ( ( rule__StringVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:6899:2: ( rule__StringVariable__Group_6_1__0 )*
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4_1()); 
-            // InternalTestgeneratorDSL.g:6867:2: ( rule__ScriptTaskFlowElement__Group_5_4_1__0 )*
-            loop56:
+             before(grammarAccess.getStringVariableAccess().getGroup_6_1()); 
+            // InternalTestgeneratorDSL.g:6900:2: ( rule__StringVariable__Group_6_1__0 )*
+            loop42:
             do {
-                int alt56=2;
-                int LA56_0 = input.LA(1);
+                int alt42=2;
+                int LA42_0 = input.LA(1);
 
-                if ( (LA56_0==RULE_SEPARATOR) ) {
-                    alt56=1;
+                if ( (LA42_0==RULE_SEPARATOR) ) {
+                    alt42=1;
                 }
 
 
-                switch (alt56) {
+                switch (alt42) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:6867:3: rule__ScriptTaskFlowElement__Group_5_4_1__0
+            	    // InternalTestgeneratorDSL.g:6900:3: rule__StringVariable__Group_6_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__ScriptTaskFlowElement__Group_5_4_1__0();
+            	    rule__StringVariable__Group_6_1__0();
 
             	    state._fsp--;
 
@@ -21271,11 +21081,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop56;
+            	    break loop42;
                 }
             } while (true);
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_5_4_1()); 
+             after(grammarAccess.getStringVariableAccess().getGroup_6_1()); 
 
             }
 
@@ -21294,26 +21104,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4__1__Impl"
+    // $ANTLR end "rule__StringVariable__Group_6__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4_1__0"
-    // InternalTestgeneratorDSL.g:6876:1: rule__ScriptTaskFlowElement__Group_5_4_1__0 : rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl rule__ScriptTaskFlowElement__Group_5_4_1__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6_1__0"
+    // InternalTestgeneratorDSL.g:6909:1: rule__StringVariable__Group_6_1__0 : rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1 ;
+    public final void rule__StringVariable__Group_6_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6880:1: ( rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl rule__ScriptTaskFlowElement__Group_5_4_1__1 )
-            // InternalTestgeneratorDSL.g:6881:2: rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl rule__ScriptTaskFlowElement__Group_5_4_1__1
+            // InternalTestgeneratorDSL.g:6913:1: ( rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1 )
+            // InternalTestgeneratorDSL.g:6914:2: rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1
             {
-            pushFollow(FOLLOW_4);
-            rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl();
+            pushFollow(FOLLOW_7);
+            rule__StringVariable__Group_6_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5_4_1__1();
+            rule__StringVariable__Group_6_1__1();
 
             state._fsp--;
 
@@ -21332,25 +21142,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4_1__0"
+    // $ANTLR end "rule__StringVariable__Group_6_1__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:6888:1: rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6_1__0__Impl"
+    // InternalTestgeneratorDSL.g:6921:1: rule__StringVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__StringVariable__Group_6_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6892:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:6893:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:6925:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:6926:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:6893:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:6894:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:6926:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:6927:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
+             before(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0()); 
+             after(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
 
             }
 
@@ -21369,21 +21179,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4_1__0__Impl"
+    // $ANTLR end "rule__StringVariable__Group_6_1__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4_1__1"
-    // InternalTestgeneratorDSL.g:6903:1: rule__ScriptTaskFlowElement__Group_5_4_1__1 : rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6_1__1"
+    // InternalTestgeneratorDSL.g:6936:1: rule__StringVariable__Group_6_1__1 : rule__StringVariable__Group_6_1__1__Impl ;
+    public final void rule__StringVariable__Group_6_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6907:1: ( rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:6908:2: rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:6940:1: ( rule__StringVariable__Group_6_1__1__Impl )
+            // InternalTestgeneratorDSL.g:6941:2: rule__StringVariable__Group_6_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl();
+            rule__StringVariable__Group_6_1__1__Impl();
 
             state._fsp--;
 
@@ -21402,35 +21212,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4_1__1"
+    // $ANTLR end "rule__StringVariable__Group_6_1__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:6914:1: rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl : ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariable__Group_6_1__1__Impl"
+    // InternalTestgeneratorDSL.g:6947:1: rule__StringVariable__Group_6_1__1__Impl : ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) ) ;
+    public final void rule__StringVariable__Group_6_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6918:1: ( ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:6919:1: ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:6951:1: ( ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:6952:1: ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6919:1: ( ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:6920:2: ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
+            // InternalTestgeneratorDSL.g:6952:1: ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:6953:2: ( rule__StringVariable__ProposalsAssignment_6_1_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
-            // InternalTestgeneratorDSL.g:6921:2: ( rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 )
-            // InternalTestgeneratorDSL.g:6921:3: rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1
+             before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); 
+            // InternalTestgeneratorDSL.g:6954:2: ( rule__StringVariable__ProposalsAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:6954:3: rule__StringVariable__ProposalsAssignment_6_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1();
+            rule__StringVariable__ProposalsAssignment_6_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesAssignment_5_4_1_1()); 
+             after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); 
 
             }
 
@@ -21449,26 +21259,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_5_4_1__1__Impl"
+    // $ANTLR end "rule__StringVariable__Group_6_1__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__0"
-    // InternalTestgeneratorDSL.g:6930:1: rule__ScriptTaskFlowElement__Group_6__0 : rule__ScriptTaskFlowElement__Group_6__0__Impl rule__ScriptTaskFlowElement__Group_6__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__0"
+    // InternalTestgeneratorDSL.g:6963:1: rule__IntVariable__Group__0 : rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1 ;
+    public final void rule__IntVariable__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6934:1: ( rule__ScriptTaskFlowElement__Group_6__0__Impl rule__ScriptTaskFlowElement__Group_6__1 )
-            // InternalTestgeneratorDSL.g:6935:2: rule__ScriptTaskFlowElement__Group_6__0__Impl rule__ScriptTaskFlowElement__Group_6__1
+            // InternalTestgeneratorDSL.g:6967:1: ( rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1 )
+            // InternalTestgeneratorDSL.g:6968:2: rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1
             {
-            pushFollow(FOLLOW_28);
-            rule__ScriptTaskFlowElement__Group_6__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__IntVariable__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__1();
+            rule__IntVariable__Group__1();
 
             state._fsp--;
 
@@ -21487,25 +21297,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__0"
+    // $ANTLR end "rule__IntVariable__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:6942:1: rule__ScriptTaskFlowElement__Group_6__0__Impl : ( 'with' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:6975:1: rule__IntVariable__Group__0__Impl : ( 'Integer' ) ;
+    public final void rule__IntVariable__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6946:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:6947:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:6979:1: ( ( 'Integer' ) )
+            // InternalTestgeneratorDSL.g:6980:1: ( 'Integer' )
             {
-            // InternalTestgeneratorDSL.g:6947:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:6948:2: 'with'
+            // InternalTestgeneratorDSL.g:6980:1: ( 'Integer' )
+            // InternalTestgeneratorDSL.g:6981:2: 'Integer'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_6_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_6_0()); 
+             before(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); 
+            match(input,57,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); 
 
             }
 
@@ -21524,26 +21334,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__0__Impl"
+    // $ANTLR end "rule__IntVariable__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__1"
-    // InternalTestgeneratorDSL.g:6957:1: rule__ScriptTaskFlowElement__Group_6__1 : rule__ScriptTaskFlowElement__Group_6__1__Impl rule__ScriptTaskFlowElement__Group_6__2 ;
-    public final void rule__ScriptTaskFlowElement__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__1"
+    // InternalTestgeneratorDSL.g:6990:1: rule__IntVariable__Group__1 : rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2 ;
+    public final void rule__IntVariable__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6961:1: ( rule__ScriptTaskFlowElement__Group_6__1__Impl rule__ScriptTaskFlowElement__Group_6__2 )
-            // InternalTestgeneratorDSL.g:6962:2: rule__ScriptTaskFlowElement__Group_6__1__Impl rule__ScriptTaskFlowElement__Group_6__2
+            // InternalTestgeneratorDSL.g:6994:1: ( rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2 )
+            // InternalTestgeneratorDSL.g:6995:2: rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2
             {
-            pushFollow(FOLLOW_12);
-            rule__ScriptTaskFlowElement__Group_6__1__Impl();
+            pushFollow(FOLLOW_5);
+            rule__IntVariable__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__2();
+            rule__IntVariable__Group__2();
 
             state._fsp--;
 
@@ -21562,25 +21372,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__1"
+    // $ANTLR end "rule__IntVariable__Group__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:6969:1: rule__ScriptTaskFlowElement__Group_6__1__Impl : ( 'outputVariables' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:7002:1: rule__IntVariable__Group__1__Impl : ( ( rule__IntVariable__NameAssignment_1 ) ) ;
+    public final void rule__IntVariable__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6973:1: ( ( 'outputVariables' ) )
-            // InternalTestgeneratorDSL.g:6974:1: ( 'outputVariables' )
+            // InternalTestgeneratorDSL.g:7006:1: ( ( ( rule__IntVariable__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:7007:1: ( ( rule__IntVariable__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:6974:1: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:6975:2: 'outputVariables'
+            // InternalTestgeneratorDSL.g:7007:1: ( ( rule__IntVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:7008:2: ( rule__IntVariable__NameAssignment_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
-            match(input,42,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesKeyword_6_1()); 
+             before(grammarAccess.getIntVariableAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:7009:2: ( rule__IntVariable__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:7009:3: rule__IntVariable__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariable__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableAccess().getNameAssignment_1()); 
 
             }
 
@@ -21599,26 +21419,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__1__Impl"
+    // $ANTLR end "rule__IntVariable__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__2"
-    // InternalTestgeneratorDSL.g:6984:1: rule__ScriptTaskFlowElement__Group_6__2 : rule__ScriptTaskFlowElement__Group_6__2__Impl rule__ScriptTaskFlowElement__Group_6__3 ;
-    public final void rule__ScriptTaskFlowElement__Group_6__2() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__2"
+    // InternalTestgeneratorDSL.g:7017:1: rule__IntVariable__Group__2 : rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3 ;
+    public final void rule__IntVariable__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:6988:1: ( rule__ScriptTaskFlowElement__Group_6__2__Impl rule__ScriptTaskFlowElement__Group_6__3 )
-            // InternalTestgeneratorDSL.g:6989:2: rule__ScriptTaskFlowElement__Group_6__2__Impl rule__ScriptTaskFlowElement__Group_6__3
+            // InternalTestgeneratorDSL.g:7021:1: ( rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3 )
+            // InternalTestgeneratorDSL.g:7022:2: rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3
             {
-            pushFollow(FOLLOW_13);
-            rule__ScriptTaskFlowElement__Group_6__2__Impl();
+            pushFollow(FOLLOW_40);
+            rule__IntVariable__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__3();
+            rule__IntVariable__Group__3();
 
             state._fsp--;
 
@@ -21637,25 +21457,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__2"
+    // $ANTLR end "rule__IntVariable__Group__2"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__2__Impl"
-    // InternalTestgeneratorDSL.g:6996:1: rule__ScriptTaskFlowElement__Group_6__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:7029:1: rule__IntVariable__Group__2__Impl : ( 'with' ) ;
+    public final void rule__IntVariable__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7000:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7001:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7033:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:7034:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:7001:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7002:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7034:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7035:2: 'with'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
+             before(grammarAccess.getIntVariableAccess().getWithKeyword_2()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getWithKeyword_2()); 
 
             }
 
@@ -21674,26 +21494,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__2__Impl"
+    // $ANTLR end "rule__IntVariable__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__3"
-    // InternalTestgeneratorDSL.g:7011:1: rule__ScriptTaskFlowElement__Group_6__3 : rule__ScriptTaskFlowElement__Group_6__3__Impl rule__ScriptTaskFlowElement__Group_6__4 ;
-    public final void rule__ScriptTaskFlowElement__Group_6__3() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__3"
+    // InternalTestgeneratorDSL.g:7044:1: rule__IntVariable__Group__3 : rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4 ;
+    public final void rule__IntVariable__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7015:1: ( rule__ScriptTaskFlowElement__Group_6__3__Impl rule__ScriptTaskFlowElement__Group_6__4 )
-            // InternalTestgeneratorDSL.g:7016:2: rule__ScriptTaskFlowElement__Group_6__3__Impl rule__ScriptTaskFlowElement__Group_6__4
+            // InternalTestgeneratorDSL.g:7048:1: ( rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4 )
+            // InternalTestgeneratorDSL.g:7049:2: rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_6__3__Impl();
+            pushFollow(FOLLOW_12);
+            rule__IntVariable__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__4();
+            rule__IntVariable__Group__4();
 
             state._fsp--;
 
@@ -21712,25 +21532,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__3"
+    // $ANTLR end "rule__IntVariable__Group__3"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__3__Impl"
-    // InternalTestgeneratorDSL.g:7023:1: rule__ScriptTaskFlowElement__Group_6__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:7056:1: rule__IntVariable__Group__3__Impl : ( 'proposals' ) ;
+    public final void rule__IntVariable__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7027:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:7028:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:7060:1: ( ( 'proposals' ) )
+            // InternalTestgeneratorDSL.g:7061:1: ( 'proposals' )
             {
-            // InternalTestgeneratorDSL.g:7028:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:7029:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:7061:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:7062:2: 'proposals'
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
+             before(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); 
+            match(input,56,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); 
 
             }
 
@@ -21749,26 +21569,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__3__Impl"
+    // $ANTLR end "rule__IntVariable__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__4"
-    // InternalTestgeneratorDSL.g:7038:1: rule__ScriptTaskFlowElement__Group_6__4 : rule__ScriptTaskFlowElement__Group_6__4__Impl rule__ScriptTaskFlowElement__Group_6__5 ;
-    public final void rule__ScriptTaskFlowElement__Group_6__4() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__4"
+    // InternalTestgeneratorDSL.g:7071:1: rule__IntVariable__Group__4 : rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5 ;
+    public final void rule__IntVariable__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7042:1: ( rule__ScriptTaskFlowElement__Group_6__4__Impl rule__ScriptTaskFlowElement__Group_6__5 )
-            // InternalTestgeneratorDSL.g:7043:2: rule__ScriptTaskFlowElement__Group_6__4__Impl rule__ScriptTaskFlowElement__Group_6__5
+            // InternalTestgeneratorDSL.g:7075:1: ( rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5 )
+            // InternalTestgeneratorDSL.g:7076:2: rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5
             {
-            pushFollow(FOLLOW_21);
-            rule__ScriptTaskFlowElement__Group_6__4__Impl();
+            pushFollow(FOLLOW_13);
+            rule__IntVariable__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__5();
+            rule__IntVariable__Group__5();
 
             state._fsp--;
 
@@ -21787,46 +21607,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__4"
+    // $ANTLR end "rule__IntVariable__Group__4"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__4__Impl"
-    // InternalTestgeneratorDSL.g:7050:1: rule__ScriptTaskFlowElement__Group_6__4__Impl : ( ( rule__ScriptTaskFlowElement__Group_6_4__0 )? ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:7083:1: rule__IntVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__IntVariable__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7054:1: ( ( ( rule__ScriptTaskFlowElement__Group_6_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:7055:1: ( ( rule__ScriptTaskFlowElement__Group_6_4__0 )? )
+            // InternalTestgeneratorDSL.g:7087:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:7088:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:7055:1: ( ( rule__ScriptTaskFlowElement__Group_6_4__0 )? )
-            // InternalTestgeneratorDSL.g:7056:2: ( rule__ScriptTaskFlowElement__Group_6_4__0 )?
+            // InternalTestgeneratorDSL.g:7088:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7089:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4()); 
-            // InternalTestgeneratorDSL.g:7057:2: ( rule__ScriptTaskFlowElement__Group_6_4__0 )?
-            int alt57=2;
-            int LA57_0 = input.LA(1);
-
-            if ( (LA57_0==RULE_ID) ) {
-                alt57=1;
-            }
-            switch (alt57) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:7057:3: rule__ScriptTaskFlowElement__Group_6_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ScriptTaskFlowElement__Group_6_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4()); 
+             before(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
 
             }
 
@@ -21845,21 +21644,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__4__Impl"
+    // $ANTLR end "rule__IntVariable__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__5"
-    // InternalTestgeneratorDSL.g:7065:1: rule__ScriptTaskFlowElement__Group_6__5 : rule__ScriptTaskFlowElement__Group_6__5__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_6__5() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__5"
+    // InternalTestgeneratorDSL.g:7098:1: rule__IntVariable__Group__5 : rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6 ;
+    public final void rule__IntVariable__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7069:1: ( rule__ScriptTaskFlowElement__Group_6__5__Impl )
-            // InternalTestgeneratorDSL.g:7070:2: rule__ScriptTaskFlowElement__Group_6__5__Impl
+            // InternalTestgeneratorDSL.g:7102:1: ( rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6 )
+            // InternalTestgeneratorDSL.g:7103:2: rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6
             {
+            pushFollow(FOLLOW_41);
+            rule__IntVariable__Group__5__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6__5__Impl();
+            rule__IntVariable__Group__6();
 
             state._fsp--;
 
@@ -21878,25 +21682,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__5"
+    // $ANTLR end "rule__IntVariable__Group__5"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6__5__Impl"
-    // InternalTestgeneratorDSL.g:7076:1: rule__ScriptTaskFlowElement__Group_6__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:7110:1: rule__IntVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__IntVariable__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7080:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:7081:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:7114:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:7115:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:7081:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:7082:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:7115:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:7116:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
+             before(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
 
             }
 
@@ -21915,26 +21719,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6__5__Impl"
+    // $ANTLR end "rule__IntVariable__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4__0"
-    // InternalTestgeneratorDSL.g:7092:1: rule__ScriptTaskFlowElement__Group_6_4__0 : rule__ScriptTaskFlowElement__Group_6_4__0__Impl rule__ScriptTaskFlowElement__Group_6_4__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__6"
+    // InternalTestgeneratorDSL.g:7125:1: rule__IntVariable__Group__6 : rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7 ;
+    public final void rule__IntVariable__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7096:1: ( rule__ScriptTaskFlowElement__Group_6_4__0__Impl rule__ScriptTaskFlowElement__Group_6_4__1 )
-            // InternalTestgeneratorDSL.g:7097:2: rule__ScriptTaskFlowElement__Group_6_4__0__Impl rule__ScriptTaskFlowElement__Group_6_4__1
+            // InternalTestgeneratorDSL.g:7129:1: ( rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7 )
+            // InternalTestgeneratorDSL.g:7130:2: rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7
             {
-            pushFollow(FOLLOW_15);
-            rule__ScriptTaskFlowElement__Group_6_4__0__Impl();
+            pushFollow(FOLLOW_41);
+            rule__IntVariable__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6_4__1();
+            rule__IntVariable__Group__7();
 
             state._fsp--;
 
@@ -21953,35 +21757,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4__0"
+    // $ANTLR end "rule__IntVariable__Group__6"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4__0__Impl"
-    // InternalTestgeneratorDSL.g:7104:1: rule__ScriptTaskFlowElement__Group_6_4__0__Impl : ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:7137:1: rule__IntVariable__Group__6__Impl : ( ( rule__IntVariable__Group_6__0 )? ) ;
+    public final void rule__IntVariable__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7108:1: ( ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:7109:1: ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
+            // InternalTestgeneratorDSL.g:7141:1: ( ( ( rule__IntVariable__Group_6__0 )? ) )
+            // InternalTestgeneratorDSL.g:7142:1: ( ( rule__IntVariable__Group_6__0 )? )
             {
-            // InternalTestgeneratorDSL.g:7109:1: ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 ) )
-            // InternalTestgeneratorDSL.g:7110:2: ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 )
+            // InternalTestgeneratorDSL.g:7142:1: ( ( rule__IntVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:7143:2: ( rule__IntVariable__Group_6__0 )?
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
-            // InternalTestgeneratorDSL.g:7111:2: ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 )
-            // InternalTestgeneratorDSL.g:7111:3: rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0();
+             before(grammarAccess.getIntVariableAccess().getGroup_6()); 
+            // InternalTestgeneratorDSL.g:7144:2: ( rule__IntVariable__Group_6__0 )?
+            int alt43=2;
+            int LA43_0 = input.LA(1);
+
+            if ( (LA43_0==RULE_INT) ) {
+                alt43=1;
+            }
+            switch (alt43) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:7144:3: rule__IntVariable__Group_6__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__IntVariable__Group_6__0();
+
+                    state._fsp--;
 
-            state._fsp--;
 
+                    }
+                    break;
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_0()); 
+             after(grammarAccess.getIntVariableAccess().getGroup_6()); 
 
             }
 
@@ -22000,21 +21815,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4__0__Impl"
+    // $ANTLR end "rule__IntVariable__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4__1"
-    // InternalTestgeneratorDSL.g:7119:1: rule__ScriptTaskFlowElement__Group_6_4__1 : rule__ScriptTaskFlowElement__Group_6_4__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__7"
+    // InternalTestgeneratorDSL.g:7152:1: rule__IntVariable__Group__7 : rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8 ;
+    public final void rule__IntVariable__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7123:1: ( rule__ScriptTaskFlowElement__Group_6_4__1__Impl )
-            // InternalTestgeneratorDSL.g:7124:2: rule__ScriptTaskFlowElement__Group_6_4__1__Impl
+            // InternalTestgeneratorDSL.g:7156:1: ( rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8 )
+            // InternalTestgeneratorDSL.g:7157:2: rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8
             {
+            pushFollow(FOLLOW_22);
+            rule__IntVariable__Group__7__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6_4__1__Impl();
+            rule__IntVariable__Group__8();
 
             state._fsp--;
 
@@ -22033,53 +21853,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4__1"
+    // $ANTLR end "rule__IntVariable__Group__7"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4__1__Impl"
-    // InternalTestgeneratorDSL.g:7130:1: rule__ScriptTaskFlowElement__Group_6_4__1__Impl : ( ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )* ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:7164:1: rule__IntVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__IntVariable__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7134:1: ( ( ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:7135:1: ( ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:7168:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:7169:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:7135:1: ( ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:7136:2: ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )*
+            // InternalTestgeneratorDSL.g:7169:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:7170:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4_1()); 
-            // InternalTestgeneratorDSL.g:7137:2: ( rule__ScriptTaskFlowElement__Group_6_4_1__0 )*
-            loop58:
-            do {
-                int alt58=2;
-                int LA58_0 = input.LA(1);
-
-                if ( (LA58_0==RULE_SEPARATOR) ) {
-                    alt58=1;
-                }
-
-
-                switch (alt58) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:7137:3: rule__ScriptTaskFlowElement__Group_6_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ScriptTaskFlowElement__Group_6_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop58;
-                }
-            } while (true);
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getGroup_6_4_1()); 
+             before(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
 
             }
 
@@ -22098,26 +21890,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4__1__Impl"
+    // $ANTLR end "rule__IntVariable__Group__7__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4_1__0"
-    // InternalTestgeneratorDSL.g:7146:1: rule__ScriptTaskFlowElement__Group_6_4_1__0 : rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl rule__ScriptTaskFlowElement__Group_6_4_1__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__8"
+    // InternalTestgeneratorDSL.g:7179:1: rule__IntVariable__Group__8 : rule__IntVariable__Group__8__Impl ;
+    public final void rule__IntVariable__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7150:1: ( rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl rule__ScriptTaskFlowElement__Group_6_4_1__1 )
-            // InternalTestgeneratorDSL.g:7151:2: rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl rule__ScriptTaskFlowElement__Group_6_4_1__1
+            // InternalTestgeneratorDSL.g:7183:1: ( rule__IntVariable__Group__8__Impl )
+            // InternalTestgeneratorDSL.g:7184:2: rule__IntVariable__Group__8__Impl
             {
-            pushFollow(FOLLOW_4);
-            rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6_4_1__1();
+            rule__IntVariable__Group__8__Impl();
 
             state._fsp--;
 
@@ -22136,25 +21923,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4_1__0"
+    // $ANTLR end "rule__IntVariable__Group__8"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:7158:1: rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:7190:1: rule__IntVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__IntVariable__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7162:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:7163:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:7194:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:7195:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:7163:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:7164:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:7195:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:7196:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
+             before(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
 
             }
 
@@ -22173,21 +21960,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4_1__0__Impl"
+    // $ANTLR end "rule__IntVariable__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4_1__1"
-    // InternalTestgeneratorDSL.g:7173:1: rule__ScriptTaskFlowElement__Group_6_4_1__1 : rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6__0"
+    // InternalTestgeneratorDSL.g:7206:1: rule__IntVariable__Group_6__0 : rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1 ;
+    public final void rule__IntVariable__Group_6__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7177:1: ( rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:7178:2: rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:7210:1: ( rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1 )
+            // InternalTestgeneratorDSL.g:7211:2: rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1
             {
+            pushFollow(FOLLOW_15);
+            rule__IntVariable__Group_6__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl();
+            rule__IntVariable__Group_6__1();
 
             state._fsp--;
 
@@ -22206,35 +21998,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4_1__1"
+    // $ANTLR end "rule__IntVariable__Group_6__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:7184:1: rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl : ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6__0__Impl"
+    // InternalTestgeneratorDSL.g:7218:1: rule__IntVariable__Group_6__0__Impl : ( ( rule__IntVariable__ProposalsAssignment_6_0 ) ) ;
+    public final void rule__IntVariable__Group_6__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7188:1: ( ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:7189:1: ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:7222:1: ( ( ( rule__IntVariable__ProposalsAssignment_6_0 ) ) )
+            // InternalTestgeneratorDSL.g:7223:1: ( ( rule__IntVariable__ProposalsAssignment_6_0 ) )
             {
-            // InternalTestgeneratorDSL.g:7189:1: ( ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:7190:2: ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
+            // InternalTestgeneratorDSL.g:7223:1: ( ( rule__IntVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:7224:2: ( rule__IntVariable__ProposalsAssignment_6_0 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
-            // InternalTestgeneratorDSL.g:7191:2: ( rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 )
-            // InternalTestgeneratorDSL.g:7191:3: rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1
+             before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); 
+            // InternalTestgeneratorDSL.g:7225:2: ( rule__IntVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:7225:3: rule__IntVariable__ProposalsAssignment_6_0
             {
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1();
+            rule__IntVariable__ProposalsAssignment_6_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesAssignment_6_4_1_1()); 
+             after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); 
 
             }
 
@@ -22253,26 +22045,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_6_4_1__1__Impl"
+    // $ANTLR end "rule__IntVariable__Group_6__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__0"
-    // InternalTestgeneratorDSL.g:7200:1: rule__ScriptTaskFlowElement__Group_7__0 : rule__ScriptTaskFlowElement__Group_7__0__Impl rule__ScriptTaskFlowElement__Group_7__1 ;
-    public final void rule__ScriptTaskFlowElement__Group_7__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6__1"
+    // InternalTestgeneratorDSL.g:7233:1: rule__IntVariable__Group_6__1 : rule__IntVariable__Group_6__1__Impl ;
+    public final void rule__IntVariable__Group_6__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7204:1: ( rule__ScriptTaskFlowElement__Group_7__0__Impl rule__ScriptTaskFlowElement__Group_7__1 )
-            // InternalTestgeneratorDSL.g:7205:2: rule__ScriptTaskFlowElement__Group_7__0__Impl rule__ScriptTaskFlowElement__Group_7__1
+            // InternalTestgeneratorDSL.g:7237:1: ( rule__IntVariable__Group_6__1__Impl )
+            // InternalTestgeneratorDSL.g:7238:2: rule__IntVariable__Group_6__1__Impl
             {
-            pushFollow(FOLLOW_29);
-            rule__ScriptTaskFlowElement__Group_7__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_7__1();
+            pushFollow(FOLLOW_2);
+            rule__IntVariable__Group_6__1__Impl();
 
             state._fsp--;
 
@@ -22291,25 +22078,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__0"
+    // $ANTLR end "rule__IntVariable__Group_6__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:7212:1: rule__ScriptTaskFlowElement__Group_7__0__Impl : ( 'and' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_7__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6__1__Impl"
+    // InternalTestgeneratorDSL.g:7244:1: rule__IntVariable__Group_6__1__Impl : ( ( rule__IntVariable__Group_6_1__0 )* ) ;
+    public final void rule__IntVariable__Group_6__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7216:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:7217:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:7248:1: ( ( ( rule__IntVariable__Group_6_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:7249:1: ( ( rule__IntVariable__Group_6_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:7217:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:7218:2: 'and'
+            // InternalTestgeneratorDSL.g:7249:1: ( ( rule__IntVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:7250:2: ( rule__IntVariable__Group_6_1__0 )*
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_7_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_7_0()); 
+             before(grammarAccess.getIntVariableAccess().getGroup_6_1()); 
+            // InternalTestgeneratorDSL.g:7251:2: ( rule__IntVariable__Group_6_1__0 )*
+            loop44:
+            do {
+                int alt44=2;
+                int LA44_0 = input.LA(1);
+
+                if ( (LA44_0==RULE_SEPARATOR) ) {
+                    alt44=1;
+                }
+
+
+                switch (alt44) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:7251:3: rule__IntVariable__Group_6_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__IntVariable__Group_6_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop44;
+                }
+            } while (true);
+
+             after(grammarAccess.getIntVariableAccess().getGroup_6_1()); 
 
             }
 
@@ -22328,26 +22143,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__0__Impl"
+    // $ANTLR end "rule__IntVariable__Group_6__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__1"
-    // InternalTestgeneratorDSL.g:7227:1: rule__ScriptTaskFlowElement__Group_7__1 : rule__ScriptTaskFlowElement__Group_7__1__Impl rule__ScriptTaskFlowElement__Group_7__2 ;
-    public final void rule__ScriptTaskFlowElement__Group_7__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6_1__0"
+    // InternalTestgeneratorDSL.g:7260:1: rule__IntVariable__Group_6_1__0 : rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1 ;
+    public final void rule__IntVariable__Group_6_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7231:1: ( rule__ScriptTaskFlowElement__Group_7__1__Impl rule__ScriptTaskFlowElement__Group_7__2 )
-            // InternalTestgeneratorDSL.g:7232:2: rule__ScriptTaskFlowElement__Group_7__1__Impl rule__ScriptTaskFlowElement__Group_7__2
+            // InternalTestgeneratorDSL.g:7264:1: ( rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1 )
+            // InternalTestgeneratorDSL.g:7265:2: rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1
             {
-            pushFollow(FOLLOW_12);
-            rule__ScriptTaskFlowElement__Group_7__1__Impl();
+            pushFollow(FOLLOW_42);
+            rule__IntVariable__Group_6_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_7__2();
+            rule__IntVariable__Group_6_1__1();
 
             state._fsp--;
 
@@ -22366,25 +22181,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__1"
+    // $ANTLR end "rule__IntVariable__Group_6_1__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:7239:1: rule__ScriptTaskFlowElement__Group_7__1__Impl : ( 'label' ) ;
-    public final void rule__ScriptTaskFlowElement__Group_7__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6_1__0__Impl"
+    // InternalTestgeneratorDSL.g:7272:1: rule__IntVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__IntVariable__Group_6_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7243:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:7244:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:7276:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:7277:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:7244:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:7245:2: 'label'
+            // InternalTestgeneratorDSL.g:7277:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:7278:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_7_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_7_1()); 
+             before(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
 
             }
 
@@ -22403,26 +22218,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__1__Impl"
+    // $ANTLR end "rule__IntVariable__Group_6_1__0__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__2"
-    // InternalTestgeneratorDSL.g:7254:1: rule__ScriptTaskFlowElement__Group_7__2 : rule__ScriptTaskFlowElement__Group_7__2__Impl rule__ScriptTaskFlowElement__Group_7__3 ;
-    public final void rule__ScriptTaskFlowElement__Group_7__2() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6_1__1"
+    // InternalTestgeneratorDSL.g:7287:1: rule__IntVariable__Group_6_1__1 : rule__IntVariable__Group_6_1__1__Impl ;
+    public final void rule__IntVariable__Group_6_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7258:1: ( rule__ScriptTaskFlowElement__Group_7__2__Impl rule__ScriptTaskFlowElement__Group_7__3 )
-            // InternalTestgeneratorDSL.g:7259:2: rule__ScriptTaskFlowElement__Group_7__2__Impl rule__ScriptTaskFlowElement__Group_7__3
+            // InternalTestgeneratorDSL.g:7291:1: ( rule__IntVariable__Group_6_1__1__Impl )
+            // InternalTestgeneratorDSL.g:7292:2: rule__IntVariable__Group_6_1__1__Impl
             {
-            pushFollow(FOLLOW_7);
-            rule__ScriptTaskFlowElement__Group_7__2__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_7__3();
+            rule__IntVariable__Group_6_1__1__Impl();
 
             state._fsp--;
 
@@ -22441,25 +22251,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__2"
+    // $ANTLR end "rule__IntVariable__Group_6_1__1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__2__Impl"
-    // InternalTestgeneratorDSL.g:7266:1: rule__ScriptTaskFlowElement__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ScriptTaskFlowElement__Group_7__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariable__Group_6_1__1__Impl"
+    // InternalTestgeneratorDSL.g:7298:1: rule__IntVariable__Group_6_1__1__Impl : ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) ) ;
+    public final void rule__IntVariable__Group_6_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7270:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7271:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7302:1: ( ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:7303:1: ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:7271:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7272:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7303:1: ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:7304:2: ( rule__IntVariable__ProposalsAssignment_6_1_1 )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); 
+            // InternalTestgeneratorDSL.g:7305:2: ( rule__IntVariable__ProposalsAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:7305:3: rule__IntVariable__ProposalsAssignment_6_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariable__ProposalsAssignment_6_1_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); 
 
             }
 
@@ -22478,21 +22298,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__2__Impl"
+    // $ANTLR end "rule__IntVariable__Group_6_1__1__Impl"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__3"
-    // InternalTestgeneratorDSL.g:7281:1: rule__ScriptTaskFlowElement__Group_7__3 : rule__ScriptTaskFlowElement__Group_7__3__Impl ;
-    public final void rule__ScriptTaskFlowElement__Group_7__3() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__0"
+    // InternalTestgeneratorDSL.g:7314:1: rule__BooleanVariable__Group__0 : rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1 ;
+    public final void rule__BooleanVariable__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7285:1: ( rule__ScriptTaskFlowElement__Group_7__3__Impl )
-            // InternalTestgeneratorDSL.g:7286:2: rule__ScriptTaskFlowElement__Group_7__3__Impl
+            // InternalTestgeneratorDSL.g:7318:1: ( rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1 )
+            // InternalTestgeneratorDSL.g:7319:2: rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1
             {
+            pushFollow(FOLLOW_4);
+            rule__BooleanVariable__Group__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__Group_7__3__Impl();
+            rule__BooleanVariable__Group__1();
 
             state._fsp--;
 
@@ -22511,35 +22336,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__3"
+    // $ANTLR end "rule__BooleanVariable__Group__0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__Group_7__3__Impl"
-    // InternalTestgeneratorDSL.g:7292:1: rule__ScriptTaskFlowElement__Group_7__3__Impl : ( ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 ) ) ;
-    public final void rule__ScriptTaskFlowElement__Group_7__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:7326:1: rule__BooleanVariable__Group__0__Impl : ( 'Boolean' ) ;
+    public final void rule__BooleanVariable__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7296:1: ( ( ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 ) ) )
-            // InternalTestgeneratorDSL.g:7297:1: ( ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:7297:1: ( ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 ) )
-            // InternalTestgeneratorDSL.g:7298:2: ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 )
+            // InternalTestgeneratorDSL.g:7330:1: ( ( 'Boolean' ) )
+            // InternalTestgeneratorDSL.g:7331:1: ( 'Boolean' )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_7_3()); 
-            // InternalTestgeneratorDSL.g:7299:2: ( rule__ScriptTaskFlowElement__LabelAssignment_7_3 )
-            // InternalTestgeneratorDSL.g:7299:3: rule__ScriptTaskFlowElement__LabelAssignment_7_3
+            // InternalTestgeneratorDSL.g:7331:1: ( 'Boolean' )
+            // InternalTestgeneratorDSL.g:7332:2: 'Boolean'
             {
-            pushFollow(FOLLOW_2);
-            rule__ScriptTaskFlowElement__LabelAssignment_7_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelAssignment_7_3()); 
+             before(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); 
+            match(input,58,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); 
 
             }
 
@@ -22558,26 +22373,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__Group_7__3__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__0__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:7308:1: rule__DelegateServiceTaskFlowElement__Group__0 : rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__1"
+    // InternalTestgeneratorDSL.g:7341:1: rule__BooleanVariable__Group__1 : rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2 ;
+    public final void rule__BooleanVariable__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7312:1: ( rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:7313:2: rule__DelegateServiceTaskFlowElement__Group__0__Impl rule__DelegateServiceTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:7345:1: ( rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2 )
+            // InternalTestgeneratorDSL.g:7346:2: rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2
             {
-            pushFollow(FOLLOW_4);
-            rule__DelegateServiceTaskFlowElement__Group__0__Impl();
+            pushFollow(FOLLOW_5);
+            rule__BooleanVariable__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__1();
+            rule__BooleanVariable__Group__2();
 
             state._fsp--;
 
@@ -22596,25 +22411,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__0"
+    // $ANTLR end "rule__BooleanVariable__Group__1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:7320:1: rule__DelegateServiceTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:7353:1: rule__BooleanVariable__Group__1__Impl : ( ( rule__BooleanVariable__NameAssignment_1 ) ) ;
+    public final void rule__BooleanVariable__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7324:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:7325:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:7357:1: ( ( ( rule__BooleanVariable__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:7358:1: ( ( rule__BooleanVariable__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:7325:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:7326:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:7358:1: ( ( rule__BooleanVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:7359:2: ( rule__BooleanVariable__NameAssignment_1 )
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:7360:2: ( rule__BooleanVariable__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:7360:3: rule__BooleanVariable__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariable__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); 
 
             }
 
@@ -22633,26 +22458,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__1__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:7335:1: rule__DelegateServiceTaskFlowElement__Group__1 : rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__2"
+    // InternalTestgeneratorDSL.g:7368:1: rule__BooleanVariable__Group__2 : rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3 ;
+    public final void rule__BooleanVariable__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7339:1: ( rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:7340:2: rule__DelegateServiceTaskFlowElement__Group__1__Impl rule__DelegateServiceTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:7372:1: ( rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3 )
+            // InternalTestgeneratorDSL.g:7373:2: rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3
             {
-            pushFollow(FOLLOW_12);
-            rule__DelegateServiceTaskFlowElement__Group__1__Impl();
+            pushFollow(FOLLOW_40);
+            rule__BooleanVariable__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__2();
+            rule__BooleanVariable__Group__3();
 
             state._fsp--;
 
@@ -22671,35 +22496,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__1"
+    // $ANTLR end "rule__BooleanVariable__Group__2"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:7347:1: rule__DelegateServiceTaskFlowElement__Group__1__Impl : ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:7380:1: rule__BooleanVariable__Group__2__Impl : ( 'with' ) ;
+    public final void rule__BooleanVariable__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7351:1: ( ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:7352:1: ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:7352:1: ( ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:7353:2: ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:7384:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:7385:1: ( 'with' )
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:7354:2: ( rule__DelegateServiceTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:7354:3: rule__DelegateServiceTaskFlowElement__NameAssignment_1
+            // InternalTestgeneratorDSL.g:7385:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7386:2: 'with'
             {
-            pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); 
 
             }
 
@@ -22718,26 +22533,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__2__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:7362:1: rule__DelegateServiceTaskFlowElement__Group__2 : rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__3"
+    // InternalTestgeneratorDSL.g:7395:1: rule__BooleanVariable__Group__3 : rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4 ;
+    public final void rule__BooleanVariable__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7366:1: ( rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:7367:2: rule__DelegateServiceTaskFlowElement__Group__2__Impl rule__DelegateServiceTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:7399:1: ( rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4 )
+            // InternalTestgeneratorDSL.g:7400:2: rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4
             {
-            pushFollow(FOLLOW_32);
-            rule__DelegateServiceTaskFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_12);
+            rule__BooleanVariable__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__3();
+            rule__BooleanVariable__Group__4();
 
             state._fsp--;
 
@@ -22756,25 +22571,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__2"
+    // $ANTLR end "rule__BooleanVariable__Group__3"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:7374:1: rule__DelegateServiceTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:7407:1: rule__BooleanVariable__Group__3__Impl : ( 'proposals' ) ;
+    public final void rule__BooleanVariable__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7378:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7379:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7411:1: ( ( 'proposals' ) )
+            // InternalTestgeneratorDSL.g:7412:1: ( 'proposals' )
             {
-            // InternalTestgeneratorDSL.g:7379:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7380:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7412:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:7413:2: 'proposals'
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); 
+            match(input,56,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); 
 
             }
 
@@ -22793,26 +22608,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__3__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:7389:1: rule__DelegateServiceTaskFlowElement__Group__3 : rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__4"
+    // InternalTestgeneratorDSL.g:7422:1: rule__BooleanVariable__Group__4 : rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5 ;
+    public final void rule__BooleanVariable__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7393:1: ( rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:7394:2: rule__DelegateServiceTaskFlowElement__Group__3__Impl rule__DelegateServiceTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:7426:1: ( rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5 )
+            // InternalTestgeneratorDSL.g:7427:2: rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5
             {
-            pushFollow(FOLLOW_5);
-            rule__DelegateServiceTaskFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_13);
+            rule__BooleanVariable__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__4();
+            rule__BooleanVariable__Group__5();
 
             state._fsp--;
 
@@ -22831,25 +22646,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__3"
+    // $ANTLR end "rule__BooleanVariable__Group__4"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:7401:1: rule__DelegateServiceTaskFlowElement__Group__3__Impl : ( 'ServiceTask' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:7434:1: rule__BooleanVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__BooleanVariable__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7405:1: ( ( 'ServiceTask' ) )
-            // InternalTestgeneratorDSL.g:7406:1: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:7438:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:7439:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:7406:1: ( 'ServiceTask' )
-            // InternalTestgeneratorDSL.g:7407:2: 'ServiceTask'
+            // InternalTestgeneratorDSL.g:7439:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7440:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
-            match(input,47,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
+             before(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
 
             }
 
@@ -22868,26 +22683,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__4__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:7416:1: rule__DelegateServiceTaskFlowElement__Group__4 : rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__5"
+    // InternalTestgeneratorDSL.g:7449:1: rule__BooleanVariable__Group__5 : rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6 ;
+    public final void rule__BooleanVariable__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7420:1: ( rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:7421:2: rule__DelegateServiceTaskFlowElement__Group__4__Impl rule__DelegateServiceTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:7453:1: ( rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6 )
+            // InternalTestgeneratorDSL.g:7454:2: rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6
             {
-            pushFollow(FOLLOW_33);
-            rule__DelegateServiceTaskFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_43);
+            rule__BooleanVariable__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__5();
+            rule__BooleanVariable__Group__6();
 
             state._fsp--;
 
@@ -22906,25 +22721,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__4"
+    // $ANTLR end "rule__BooleanVariable__Group__5"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:7428:1: rule__DelegateServiceTaskFlowElement__Group__4__Impl : ( 'with' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:7461:1: rule__BooleanVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__BooleanVariable__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7432:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:7433:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7465:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:7466:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:7433:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:7434:2: 'with'
+            // InternalTestgeneratorDSL.g:7466:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:7467:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4()); 
+             before(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
 
             }
 
@@ -22943,26 +22758,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__5__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:7443:1: rule__DelegateServiceTaskFlowElement__Group__5 : rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__6"
+    // InternalTestgeneratorDSL.g:7476:1: rule__BooleanVariable__Group__6 : rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7 ;
+    public final void rule__BooleanVariable__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7447:1: ( rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:7448:2: rule__DelegateServiceTaskFlowElement__Group__5__Impl rule__DelegateServiceTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:7480:1: ( rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7 )
+            // InternalTestgeneratorDSL.g:7481:2: rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7
             {
-            pushFollow(FOLLOW_12);
-            rule__DelegateServiceTaskFlowElement__Group__5__Impl();
+            pushFollow(FOLLOW_43);
+            rule__BooleanVariable__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__6();
+            rule__BooleanVariable__Group__7();
 
             state._fsp--;
 
@@ -22981,25 +22796,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__5"
+    // $ANTLR end "rule__BooleanVariable__Group__6"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:7455:1: rule__DelegateServiceTaskFlowElement__Group__5__Impl : ( 'delegate' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:7488:1: rule__BooleanVariable__Group__6__Impl : ( ( rule__BooleanVariable__Group_6__0 )? ) ;
+    public final void rule__BooleanVariable__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7459:1: ( ( 'delegate' ) )
-            // InternalTestgeneratorDSL.g:7460:1: ( 'delegate' )
+            // InternalTestgeneratorDSL.g:7492:1: ( ( ( rule__BooleanVariable__Group_6__0 )? ) )
+            // InternalTestgeneratorDSL.g:7493:1: ( ( rule__BooleanVariable__Group_6__0 )? )
             {
-            // InternalTestgeneratorDSL.g:7460:1: ( 'delegate' )
-            // InternalTestgeneratorDSL.g:7461:2: 'delegate'
+            // InternalTestgeneratorDSL.g:7493:1: ( ( rule__BooleanVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:7494:2: ( rule__BooleanVariable__Group_6__0 )?
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); 
-            match(input,48,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5()); 
+             before(grammarAccess.getBooleanVariableAccess().getGroup_6()); 
+            // InternalTestgeneratorDSL.g:7495:2: ( rule__BooleanVariable__Group_6__0 )?
+            int alt45=2;
+            int LA45_0 = input.LA(1);
+
+            if ( ((LA45_0>=16 && LA45_0<=17)) ) {
+                alt45=1;
+            }
+            switch (alt45) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:7495:3: rule__BooleanVariable__Group_6__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__BooleanVariable__Group_6__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getBooleanVariableAccess().getGroup_6()); 
 
             }
 
@@ -23018,26 +22854,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__6__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:7470:1: rule__DelegateServiceTaskFlowElement__Group__6 : rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__7"
+    // InternalTestgeneratorDSL.g:7503:1: rule__BooleanVariable__Group__7 : rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8 ;
+    public final void rule__BooleanVariable__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7474:1: ( rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:7475:2: rule__DelegateServiceTaskFlowElement__Group__6__Impl rule__DelegateServiceTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:7507:1: ( rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8 )
+            // InternalTestgeneratorDSL.g:7508:2: rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8
             {
-            pushFollow(FOLLOW_7);
-            rule__DelegateServiceTaskFlowElement__Group__6__Impl();
+            pushFollow(FOLLOW_22);
+            rule__BooleanVariable__Group__7__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__7();
+            rule__BooleanVariable__Group__8();
 
             state._fsp--;
 
@@ -23056,25 +22892,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__6"
+    // $ANTLR end "rule__BooleanVariable__Group__7"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:7482:1: rule__DelegateServiceTaskFlowElement__Group__6__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:7515:1: rule__BooleanVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__BooleanVariable__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7486:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7487:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7519:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:7520:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:7487:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7488:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7520:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:7521:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
+             before(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
 
             }
 
@@ -23093,26 +22929,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__7__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:7497:1: rule__DelegateServiceTaskFlowElement__Group__7 : rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__8"
+    // InternalTestgeneratorDSL.g:7530:1: rule__BooleanVariable__Group__8 : rule__BooleanVariable__Group__8__Impl ;
+    public final void rule__BooleanVariable__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7501:1: ( rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:7502:2: rule__DelegateServiceTaskFlowElement__Group__7__Impl rule__DelegateServiceTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:7534:1: ( rule__BooleanVariable__Group__8__Impl )
+            // InternalTestgeneratorDSL.g:7535:2: rule__BooleanVariable__Group__8__Impl
             {
-            pushFollow(FOLLOW_34);
-            rule__DelegateServiceTaskFlowElement__Group__7__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__8();
+            rule__BooleanVariable__Group__8__Impl();
 
             state._fsp--;
 
@@ -23131,35 +22962,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__7"
+    // $ANTLR end "rule__BooleanVariable__Group__8"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:7509:1: rule__DelegateServiceTaskFlowElement__Group__7__Impl : ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:7541:1: rule__BooleanVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__BooleanVariable__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7513:1: ( ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) ) )
-            // InternalTestgeneratorDSL.g:7514:1: ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:7545:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:7546:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:7514:1: ( ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 ) )
-            // InternalTestgeneratorDSL.g:7515:2: ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 )
+            // InternalTestgeneratorDSL.g:7546:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:7547:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); 
-            // InternalTestgeneratorDSL.g:7516:2: ( rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 )
-            // InternalTestgeneratorDSL.g:7516:3: rule__DelegateServiceTaskFlowElement__DelegateAssignment_7
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__DelegateAssignment_7();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateAssignment_7()); 
+             before(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
 
             }
 
@@ -23178,26 +22999,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group__8__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:7524:1: rule__DelegateServiceTaskFlowElement__Group__8 : rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6__0"
+    // InternalTestgeneratorDSL.g:7557:1: rule__BooleanVariable__Group_6__0 : rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1 ;
+    public final void rule__BooleanVariable__Group_6__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7528:1: ( rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9 )
-            // InternalTestgeneratorDSL.g:7529:2: rule__DelegateServiceTaskFlowElement__Group__8__Impl rule__DelegateServiceTaskFlowElement__Group__9
+            // InternalTestgeneratorDSL.g:7561:1: ( rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1 )
+            // InternalTestgeneratorDSL.g:7562:2: rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1
             {
-            pushFollow(FOLLOW_34);
-            rule__DelegateServiceTaskFlowElement__Group__8__Impl();
+            pushFollow(FOLLOW_15);
+            rule__BooleanVariable__Group_6__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__9();
+            rule__BooleanVariable__Group_6__1();
 
             state._fsp--;
 
@@ -23216,46 +23037,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__8"
+    // $ANTLR end "rule__BooleanVariable__Group_6__0"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:7536:1: rule__DelegateServiceTaskFlowElement__Group__8__Impl : ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6__0__Impl"
+    // InternalTestgeneratorDSL.g:7569:1: rule__BooleanVariable__Group_6__0__Impl : ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) ) ;
+    public final void rule__BooleanVariable__Group_6__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7540:1: ( ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? ) )
-            // InternalTestgeneratorDSL.g:7541:1: ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? )
+            // InternalTestgeneratorDSL.g:7573:1: ( ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) ) )
+            // InternalTestgeneratorDSL.g:7574:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) )
             {
-            // InternalTestgeneratorDSL.g:7541:1: ( ( rule__DelegateServiceTaskFlowElement__Group_8__0 )? )
-            // InternalTestgeneratorDSL.g:7542:2: ( rule__DelegateServiceTaskFlowElement__Group_8__0 )?
+            // InternalTestgeneratorDSL.g:7574:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:7575:2: ( rule__BooleanVariable__ProposalsAssignment_6_0 )
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); 
-            // InternalTestgeneratorDSL.g:7543:2: ( rule__DelegateServiceTaskFlowElement__Group_8__0 )?
-            int alt59=2;
-            int LA59_0 = input.LA(1);
-
-            if ( (LA59_0==43) ) {
-                alt59=1;
-            }
-            switch (alt59) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:7543:3: rule__DelegateServiceTaskFlowElement__Group_8__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__DelegateServiceTaskFlowElement__Group_8__0();
-
-                    state._fsp--;
+             before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); 
+            // InternalTestgeneratorDSL.g:7576:2: ( rule__BooleanVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:7576:3: rule__BooleanVariable__ProposalsAssignment_6_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariable__ProposalsAssignment_6_0();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getGroup_8()); 
+             after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); 
 
             }
 
@@ -23274,21 +23084,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__8__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group_6__0__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__9"
-    // InternalTestgeneratorDSL.g:7551:1: rule__DelegateServiceTaskFlowElement__Group__9 : rule__DelegateServiceTaskFlowElement__Group__9__Impl ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__9() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6__1"
+    // InternalTestgeneratorDSL.g:7584:1: rule__BooleanVariable__Group_6__1 : rule__BooleanVariable__Group_6__1__Impl ;
+    public final void rule__BooleanVariable__Group_6__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7555:1: ( rule__DelegateServiceTaskFlowElement__Group__9__Impl )
-            // InternalTestgeneratorDSL.g:7556:2: rule__DelegateServiceTaskFlowElement__Group__9__Impl
+            // InternalTestgeneratorDSL.g:7588:1: ( rule__BooleanVariable__Group_6__1__Impl )
+            // InternalTestgeneratorDSL.g:7589:2: rule__BooleanVariable__Group_6__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group__9__Impl();
+            rule__BooleanVariable__Group_6__1__Impl();
 
             state._fsp--;
 
@@ -23307,25 +23117,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__9"
+    // $ANTLR end "rule__BooleanVariable__Group_6__1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:7562:1: rule__DelegateServiceTaskFlowElement__Group__9__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group__9__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6__1__Impl"
+    // InternalTestgeneratorDSL.g:7595:1: rule__BooleanVariable__Group_6__1__Impl : ( ( rule__BooleanVariable__Group_6_1__0 )* ) ;
+    public final void rule__BooleanVariable__Group_6__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7566:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:7567:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:7599:1: ( ( ( rule__BooleanVariable__Group_6_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:7600:1: ( ( rule__BooleanVariable__Group_6_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:7567:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:7568:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:7600:1: ( ( rule__BooleanVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:7601:2: ( rule__BooleanVariable__Group_6_1__0 )*
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
+             before(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); 
+            // InternalTestgeneratorDSL.g:7602:2: ( rule__BooleanVariable__Group_6_1__0 )*
+            loop46:
+            do {
+                int alt46=2;
+                int LA46_0 = input.LA(1);
+
+                if ( (LA46_0==RULE_SEPARATOR) ) {
+                    alt46=1;
+                }
+
+
+                switch (alt46) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:7602:3: rule__BooleanVariable__Group_6_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__BooleanVariable__Group_6_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop46;
+                }
+            } while (true);
+
+             after(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); 
 
             }
 
@@ -23344,26 +23182,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group__9__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group_6__1__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__0"
-    // InternalTestgeneratorDSL.g:7578:1: rule__DelegateServiceTaskFlowElement__Group_8__0 : rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__0() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6_1__0"
+    // InternalTestgeneratorDSL.g:7611:1: rule__BooleanVariable__Group_6_1__0 : rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1 ;
+    public final void rule__BooleanVariable__Group_6_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7582:1: ( rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1 )
-            // InternalTestgeneratorDSL.g:7583:2: rule__DelegateServiceTaskFlowElement__Group_8__0__Impl rule__DelegateServiceTaskFlowElement__Group_8__1
+            // InternalTestgeneratorDSL.g:7615:1: ( rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1 )
+            // InternalTestgeneratorDSL.g:7616:2: rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1
             {
-            pushFollow(FOLLOW_29);
-            rule__DelegateServiceTaskFlowElement__Group_8__0__Impl();
+            pushFollow(FOLLOW_44);
+            rule__BooleanVariable__Group_6_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group_8__1();
+            rule__BooleanVariable__Group_6_1__1();
 
             state._fsp--;
 
@@ -23382,25 +23220,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__0"
+    // $ANTLR end "rule__BooleanVariable__Group_6_1__0"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__0__Impl"
-    // InternalTestgeneratorDSL.g:7590:1: rule__DelegateServiceTaskFlowElement__Group_8__0__Impl : ( 'and' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6_1__0__Impl"
+    // InternalTestgeneratorDSL.g:7623:1: rule__BooleanVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__BooleanVariable__Group_6_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7594:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:7595:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:7627:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:7628:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:7595:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:7596:2: 'and'
+            // InternalTestgeneratorDSL.g:7628:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:7629:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0()); 
+             before(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
 
             }
 
@@ -23419,26 +23257,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__0__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group_6_1__0__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__1"
-    // InternalTestgeneratorDSL.g:7605:1: rule__DelegateServiceTaskFlowElement__Group_8__1 : rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6_1__1"
+    // InternalTestgeneratorDSL.g:7638:1: rule__BooleanVariable__Group_6_1__1 : rule__BooleanVariable__Group_6_1__1__Impl ;
+    public final void rule__BooleanVariable__Group_6_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7609:1: ( rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2 )
-            // InternalTestgeneratorDSL.g:7610:2: rule__DelegateServiceTaskFlowElement__Group_8__1__Impl rule__DelegateServiceTaskFlowElement__Group_8__2
+            // InternalTestgeneratorDSL.g:7642:1: ( rule__BooleanVariable__Group_6_1__1__Impl )
+            // InternalTestgeneratorDSL.g:7643:2: rule__BooleanVariable__Group_6_1__1__Impl
             {
-            pushFollow(FOLLOW_12);
-            rule__DelegateServiceTaskFlowElement__Group_8__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group_8__2();
+            rule__BooleanVariable__Group_6_1__1__Impl();
 
             state._fsp--;
 
@@ -23457,25 +23290,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__1"
+    // $ANTLR end "rule__BooleanVariable__Group_6_1__1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__1__Impl"
-    // InternalTestgeneratorDSL.g:7617:1: rule__DelegateServiceTaskFlowElement__Group_8__1__Impl : ( 'label' ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariable__Group_6_1__1__Impl"
+    // InternalTestgeneratorDSL.g:7649:1: rule__BooleanVariable__Group_6_1__1__Impl : ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) ) ;
+    public final void rule__BooleanVariable__Group_6_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7621:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:7622:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:7653:1: ( ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:7654:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:7622:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:7623:2: 'label'
+            // InternalTestgeneratorDSL.g:7654:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:7655:2: ( rule__BooleanVariable__ProposalsAssignment_6_1_1 )
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1()); 
+             before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); 
+            // InternalTestgeneratorDSL.g:7656:2: ( rule__BooleanVariable__ProposalsAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:7656:3: rule__BooleanVariable__ProposalsAssignment_6_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariable__ProposalsAssignment_6_1_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); 
 
             }
 
@@ -23494,26 +23337,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__1__Impl"
+    // $ANTLR end "rule__BooleanVariable__Group_6_1__1__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__2"
-    // InternalTestgeneratorDSL.g:7632:1: rule__DelegateServiceTaskFlowElement__Group_8__2 : rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3 ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__2() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__0"
+    // InternalTestgeneratorDSL.g:7665:1: rule__Loop__Group__0 : rule__Loop__Group__0__Impl rule__Loop__Group__1 ;
+    public final void rule__Loop__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7636:1: ( rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3 )
-            // InternalTestgeneratorDSL.g:7637:2: rule__DelegateServiceTaskFlowElement__Group_8__2__Impl rule__DelegateServiceTaskFlowElement__Group_8__3
+            // InternalTestgeneratorDSL.g:7669:1: ( rule__Loop__Group__0__Impl rule__Loop__Group__1 )
+            // InternalTestgeneratorDSL.g:7670:2: rule__Loop__Group__0__Impl rule__Loop__Group__1
             {
-            pushFollow(FOLLOW_7);
-            rule__DelegateServiceTaskFlowElement__Group_8__2__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Loop__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group_8__3();
+            rule__Loop__Group__1();
 
             state._fsp--;
 
@@ -23532,25 +23375,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__2"
+    // $ANTLR end "rule__Loop__Group__0"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__2__Impl"
-    // InternalTestgeneratorDSL.g:7644:1: rule__DelegateServiceTaskFlowElement__Group_8__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:7677:1: rule__Loop__Group__0__Impl : ( 'Loop' ) ;
+    public final void rule__Loop__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7648:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7649:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7681:1: ( ( 'Loop' ) )
+            // InternalTestgeneratorDSL.g:7682:1: ( 'Loop' )
             {
-            // InternalTestgeneratorDSL.g:7649:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7650:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7682:1: ( 'Loop' )
+            // InternalTestgeneratorDSL.g:7683:2: 'Loop'
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
+             before(grammarAccess.getLoopAccess().getLoopKeyword_0()); 
+            match(input,59,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getLoopKeyword_0()); 
 
             }
 
@@ -23569,21 +23412,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__2__Impl"
+    // $ANTLR end "rule__Loop__Group__0__Impl"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__3"
-    // InternalTestgeneratorDSL.g:7659:1: rule__DelegateServiceTaskFlowElement__Group_8__3 : rule__DelegateServiceTaskFlowElement__Group_8__3__Impl ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__3() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__1"
+    // InternalTestgeneratorDSL.g:7692:1: rule__Loop__Group__1 : rule__Loop__Group__1__Impl rule__Loop__Group__2 ;
+    public final void rule__Loop__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7663:1: ( rule__DelegateServiceTaskFlowElement__Group_8__3__Impl )
-            // InternalTestgeneratorDSL.g:7664:2: rule__DelegateServiceTaskFlowElement__Group_8__3__Impl
+            // InternalTestgeneratorDSL.g:7696:1: ( rule__Loop__Group__1__Impl rule__Loop__Group__2 )
+            // InternalTestgeneratorDSL.g:7697:2: rule__Loop__Group__1__Impl rule__Loop__Group__2
             {
+            pushFollow(FOLLOW_45);
+            rule__Loop__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__Group_8__3__Impl();
+            rule__Loop__Group__2();
 
             state._fsp--;
 
@@ -23602,35 +23450,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__3"
+    // $ANTLR end "rule__Loop__Group__1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__Group_8__3__Impl"
-    // InternalTestgeneratorDSL.g:7670:1: rule__DelegateServiceTaskFlowElement__Group_8__3__Impl : ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) ) ;
-    public final void rule__DelegateServiceTaskFlowElement__Group_8__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:7704:1: rule__Loop__Group__1__Impl : ( ( rule__Loop__NameAssignment_1 ) ) ;
+    public final void rule__Loop__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7674:1: ( ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) ) )
-            // InternalTestgeneratorDSL.g:7675:1: ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) )
+            // InternalTestgeneratorDSL.g:7708:1: ( ( ( rule__Loop__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:7709:1: ( ( rule__Loop__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:7675:1: ( ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 ) )
-            // InternalTestgeneratorDSL.g:7676:2: ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 )
+            // InternalTestgeneratorDSL.g:7709:1: ( ( rule__Loop__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:7710:2: ( rule__Loop__NameAssignment_1 )
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); 
-            // InternalTestgeneratorDSL.g:7677:2: ( rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 )
-            // InternalTestgeneratorDSL.g:7677:3: rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3
+             before(grammarAccess.getLoopAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:7711:2: ( rule__Loop__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:7711:3: rule__Loop__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3();
+            rule__Loop__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelAssignment_8_3()); 
+             after(grammarAccess.getLoopAccess().getNameAssignment_1()); 
 
             }
 
@@ -23649,26 +23497,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__Group_8__3__Impl"
+    // $ANTLR end "rule__Loop__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:7686:1: rule__ExternalServiceTaskFlowElement__Group__0 : rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__2"
+    // InternalTestgeneratorDSL.g:7719:1: rule__Loop__Group__2 : rule__Loop__Group__2__Impl rule__Loop__Group__3 ;
+    public final void rule__Loop__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7690:1: ( rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:7691:2: rule__ExternalServiceTaskFlowElement__Group__0__Impl rule__ExternalServiceTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:7723:1: ( rule__Loop__Group__2__Impl rule__Loop__Group__3 )
+            // InternalTestgeneratorDSL.g:7724:2: rule__Loop__Group__2__Impl rule__Loop__Group__3
             {
-            pushFollow(FOLLOW_4);
-            rule__ExternalServiceTaskFlowElement__Group__0__Impl();
+            pushFollow(FOLLOW_5);
+            rule__Loop__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__1();
+            rule__Loop__Group__3();
 
             state._fsp--;
 
@@ -23687,25 +23535,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__0"
+    // $ANTLR end "rule__Loop__Group__2"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:7698:1: rule__ExternalServiceTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:7731:1: rule__Loop__Group__2__Impl : ( 'starts' ) ;
+    public final void rule__Loop__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7702:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:7703:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:7735:1: ( ( 'starts' ) )
+            // InternalTestgeneratorDSL.g:7736:1: ( 'starts' )
             {
-            // InternalTestgeneratorDSL.g:7703:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:7704:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:7736:1: ( 'starts' )
+            // InternalTestgeneratorDSL.g:7737:2: 'starts'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getLoopAccess().getStartsKeyword_2()); 
+            match(input,60,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getStartsKeyword_2()); 
 
             }
 
@@ -23724,26 +23572,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__Loop__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:7713:1: rule__ExternalServiceTaskFlowElement__Group__1 : rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__3"
+    // InternalTestgeneratorDSL.g:7746:1: rule__Loop__Group__3 : rule__Loop__Group__3__Impl rule__Loop__Group__4 ;
+    public final void rule__Loop__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7717:1: ( rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:7718:2: rule__ExternalServiceTaskFlowElement__Group__1__Impl rule__ExternalServiceTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:7750:1: ( rule__Loop__Group__3__Impl rule__Loop__Group__4 )
+            // InternalTestgeneratorDSL.g:7751:2: rule__Loop__Group__3__Impl rule__Loop__Group__4
             {
-            pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group__1__Impl();
+            pushFollow(FOLLOW_7);
+            rule__Loop__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__2();
+            rule__Loop__Group__4();
 
             state._fsp--;
 
@@ -23762,35 +23610,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__1"
+    // $ANTLR end "rule__Loop__Group__3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:7725:1: rule__ExternalServiceTaskFlowElement__Group__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:7758:1: rule__Loop__Group__3__Impl : ( 'with' ) ;
+    public final void rule__Loop__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7729:1: ( ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:7730:1: ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:7762:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:7763:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:7730:1: ( ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:7731:2: ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:7763:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7764:2: 'with'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:7732:2: ( rule__ExternalServiceTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:7732:3: rule__ExternalServiceTaskFlowElement__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getLoopAccess().getWithKeyword_3()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getWithKeyword_3()); 
 
             }
 
@@ -23809,26 +23647,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__Loop__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:7740:1: rule__ExternalServiceTaskFlowElement__Group__2 : rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__4"
+    // InternalTestgeneratorDSL.g:7773:1: rule__Loop__Group__4 : rule__Loop__Group__4__Impl rule__Loop__Group__5 ;
+    public final void rule__Loop__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7744:1: ( rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:7745:2: rule__ExternalServiceTaskFlowElement__Group__2__Impl rule__ExternalServiceTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:7777:1: ( rule__Loop__Group__4__Impl rule__Loop__Group__5 )
+            // InternalTestgeneratorDSL.g:7778:2: rule__Loop__Group__4__Impl rule__Loop__Group__5
             {
-            pushFollow(FOLLOW_32);
-            rule__ExternalServiceTaskFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_46);
+            rule__Loop__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__3();
+            rule__Loop__Group__5();
 
             state._fsp--;
 
@@ -23847,25 +23685,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__2"
+    // $ANTLR end "rule__Loop__Group__4"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:7752:1: rule__ExternalServiceTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:7785:1: rule__Loop__Group__4__Impl : ( ( rule__Loop__StartAssignment_4 ) ) ;
+    public final void rule__Loop__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7756:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7757:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7789:1: ( ( ( rule__Loop__StartAssignment_4 ) ) )
+            // InternalTestgeneratorDSL.g:7790:1: ( ( rule__Loop__StartAssignment_4 ) )
             {
-            // InternalTestgeneratorDSL.g:7757:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7758:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7790:1: ( ( rule__Loop__StartAssignment_4 ) )
+            // InternalTestgeneratorDSL.g:7791:2: ( rule__Loop__StartAssignment_4 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getLoopAccess().getStartAssignment_4()); 
+            // InternalTestgeneratorDSL.g:7792:2: ( rule__Loop__StartAssignment_4 )
+            // InternalTestgeneratorDSL.g:7792:3: rule__Loop__StartAssignment_4
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__StartAssignment_4();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getLoopAccess().getStartAssignment_4()); 
 
             }
 
@@ -23884,26 +23732,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__Loop__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:7767:1: rule__ExternalServiceTaskFlowElement__Group__3 : rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__5"
+    // InternalTestgeneratorDSL.g:7800:1: rule__Loop__Group__5 : rule__Loop__Group__5__Impl rule__Loop__Group__6 ;
+    public final void rule__Loop__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7771:1: ( rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:7772:2: rule__ExternalServiceTaskFlowElement__Group__3__Impl rule__ExternalServiceTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:7804:1: ( rule__Loop__Group__5__Impl rule__Loop__Group__6 )
+            // InternalTestgeneratorDSL.g:7805:2: rule__Loop__Group__5__Impl rule__Loop__Group__6
             {
-            pushFollow(FOLLOW_5);
-            rule__ExternalServiceTaskFlowElement__Group__3__Impl();
+            pushFollow(FOLLOW_47);
+            rule__Loop__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__4();
+            rule__Loop__Group__6();
 
             state._fsp--;
 
@@ -23922,25 +23770,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__3"
+    // $ANTLR end "rule__Loop__Group__5"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:7779:1: rule__ExternalServiceTaskFlowElement__Group__3__Impl : ( 'ServiceTask' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:7812:1: rule__Loop__Group__5__Impl : ( 'follows' ) ;
+    public final void rule__Loop__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7783:1: ( ( 'ServiceTask' ) )
-            // InternalTestgeneratorDSL.g:7784:1: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:7816:1: ( ( 'follows' ) )
+            // InternalTestgeneratorDSL.g:7817:1: ( 'follows' )
             {
-            // InternalTestgeneratorDSL.g:7784:1: ( 'ServiceTask' )
-            // InternalTestgeneratorDSL.g:7785:2: 'ServiceTask'
+            // InternalTestgeneratorDSL.g:7817:1: ( 'follows' )
+            // InternalTestgeneratorDSL.g:7818:2: 'follows'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
-            match(input,47,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3()); 
+             before(grammarAccess.getLoopAccess().getFollowsKeyword_5()); 
+            match(input,61,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getFollowsKeyword_5()); 
 
             }
 
@@ -23959,26 +23807,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__Loop__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:7794:1: rule__ExternalServiceTaskFlowElement__Group__4 : rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__6"
+    // InternalTestgeneratorDSL.g:7827:1: rule__Loop__Group__6 : rule__Loop__Group__6__Impl rule__Loop__Group__7 ;
+    public final void rule__Loop__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7798:1: ( rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:7799:2: rule__ExternalServiceTaskFlowElement__Group__4__Impl rule__ExternalServiceTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:7831:1: ( rule__Loop__Group__6__Impl rule__Loop__Group__7 )
+            // InternalTestgeneratorDSL.g:7832:2: rule__Loop__Group__6__Impl rule__Loop__Group__7
             {
-            pushFollow(FOLLOW_35);
-            rule__ExternalServiceTaskFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_7);
+            rule__Loop__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__5();
+            rule__Loop__Group__7();
 
             state._fsp--;
 
@@ -23997,25 +23845,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__4"
+    // $ANTLR end "rule__Loop__Group__6"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:7806:1: rule__ExternalServiceTaskFlowElement__Group__4__Impl : ( 'with' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:7839:1: rule__Loop__Group__6__Impl : ( 'by' ) ;
+    public final void rule__Loop__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7810:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:7811:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7843:1: ( ( 'by' ) )
+            // InternalTestgeneratorDSL.g:7844:1: ( 'by' )
             {
-            // InternalTestgeneratorDSL.g:7811:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:7812:2: 'with'
+            // InternalTestgeneratorDSL.g:7844:1: ( 'by' )
+            // InternalTestgeneratorDSL.g:7845:2: 'by'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4()); 
+             before(grammarAccess.getLoopAccess().getByKeyword_6()); 
+            match(input,62,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getByKeyword_6()); 
 
             }
 
@@ -24034,26 +23882,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__Loop__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:7821:1: rule__ExternalServiceTaskFlowElement__Group__5 : rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__7"
+    // InternalTestgeneratorDSL.g:7854:1: rule__Loop__Group__7 : rule__Loop__Group__7__Impl rule__Loop__Group__8 ;
+    public final void rule__Loop__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7825:1: ( rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:7826:2: rule__ExternalServiceTaskFlowElement__Group__5__Impl rule__ExternalServiceTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:7858:1: ( rule__Loop__Group__7__Impl rule__Loop__Group__8 )
+            // InternalTestgeneratorDSL.g:7859:2: rule__Loop__Group__7__Impl rule__Loop__Group__8
             {
-            pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group__5__Impl();
+            pushFollow(FOLLOW_48);
+            rule__Loop__Group__7__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__6();
+            rule__Loop__Group__8();
 
             state._fsp--;
 
@@ -24072,25 +23920,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__5"
+    // $ANTLR end "rule__Loop__Group__7"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:7833:1: rule__ExternalServiceTaskFlowElement__Group__5__Impl : ( 'external' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:7866:1: rule__Loop__Group__7__Impl : ( ( rule__Loop__FollowerAssignment_7 ) ) ;
+    public final void rule__Loop__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7837:1: ( ( 'external' ) )
-            // InternalTestgeneratorDSL.g:7838:1: ( 'external' )
+            // InternalTestgeneratorDSL.g:7870:1: ( ( ( rule__Loop__FollowerAssignment_7 ) ) )
+            // InternalTestgeneratorDSL.g:7871:1: ( ( rule__Loop__FollowerAssignment_7 ) )
             {
-            // InternalTestgeneratorDSL.g:7838:1: ( 'external' )
-            // InternalTestgeneratorDSL.g:7839:2: 'external'
+            // InternalTestgeneratorDSL.g:7871:1: ( ( rule__Loop__FollowerAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:7872:2: ( rule__Loop__FollowerAssignment_7 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); 
-            match(input,49,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5()); 
+             before(grammarAccess.getLoopAccess().getFollowerAssignment_7()); 
+            // InternalTestgeneratorDSL.g:7873:2: ( rule__Loop__FollowerAssignment_7 )
+            // InternalTestgeneratorDSL.g:7873:3: rule__Loop__FollowerAssignment_7
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__FollowerAssignment_7();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getLoopAccess().getFollowerAssignment_7()); 
 
             }
 
@@ -24109,26 +23967,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__Loop__Group__7__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:7848:1: rule__ExternalServiceTaskFlowElement__Group__6 : rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__8"
+    // InternalTestgeneratorDSL.g:7881:1: rule__Loop__Group__8 : rule__Loop__Group__8__Impl rule__Loop__Group__9 ;
+    public final void rule__Loop__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7852:1: ( rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:7853:2: rule__ExternalServiceTaskFlowElement__Group__6__Impl rule__ExternalServiceTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:7885:1: ( rule__Loop__Group__8__Impl rule__Loop__Group__9 )
+            // InternalTestgeneratorDSL.g:7886:2: rule__Loop__Group__8__Impl rule__Loop__Group__9
             {
-            pushFollow(FOLLOW_4);
-            rule__ExternalServiceTaskFlowElement__Group__6__Impl();
+            pushFollow(FOLLOW_5);
+            rule__Loop__Group__8__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__7();
+            rule__Loop__Group__9();
 
             state._fsp--;
 
@@ -24147,25 +24005,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__6"
+    // $ANTLR end "rule__Loop__Group__8"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:7860:1: rule__ExternalServiceTaskFlowElement__Group__6__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:7893:1: rule__Loop__Group__8__Impl : ( 'ends' ) ;
+    public final void rule__Loop__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7864:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:7865:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:7897:1: ( ( 'ends' ) )
+            // InternalTestgeneratorDSL.g:7898:1: ( 'ends' )
             {
-            // InternalTestgeneratorDSL.g:7865:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:7866:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:7898:1: ( 'ends' )
+            // InternalTestgeneratorDSL.g:7899:2: 'ends'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6()); 
+             before(grammarAccess.getLoopAccess().getEndsKeyword_8()); 
+            match(input,63,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getEndsKeyword_8()); 
 
             }
 
@@ -24184,26 +24042,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__Loop__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:7875:1: rule__ExternalServiceTaskFlowElement__Group__7 : rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__9"
+    // InternalTestgeneratorDSL.g:7908:1: rule__Loop__Group__9 : rule__Loop__Group__9__Impl rule__Loop__Group__10 ;
+    public final void rule__Loop__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7879:1: ( rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:7880:2: rule__ExternalServiceTaskFlowElement__Group__7__Impl rule__ExternalServiceTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:7912:1: ( rule__Loop__Group__9__Impl rule__Loop__Group__10 )
+            // InternalTestgeneratorDSL.g:7913:2: rule__Loop__Group__9__Impl rule__Loop__Group__10
             {
-            pushFollow(FOLLOW_26);
-            rule__ExternalServiceTaskFlowElement__Group__7__Impl();
+            pushFollow(FOLLOW_7);
+            rule__Loop__Group__9__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__8();
+            rule__Loop__Group__10();
 
             state._fsp--;
 
@@ -24222,35 +24080,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__7"
+    // $ANTLR end "rule__Loop__Group__9"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:7887:1: rule__ExternalServiceTaskFlowElement__Group__7__Impl : ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__9__Impl"
+    // InternalTestgeneratorDSL.g:7920:1: rule__Loop__Group__9__Impl : ( 'with' ) ;
+    public final void rule__Loop__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7891:1: ( ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) ) )
-            // InternalTestgeneratorDSL.g:7892:1: ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) )
+            // InternalTestgeneratorDSL.g:7924:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:7925:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:7892:1: ( ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 ) )
-            // InternalTestgeneratorDSL.g:7893:2: ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 )
+            // InternalTestgeneratorDSL.g:7925:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:7926:2: 'with'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); 
-            // InternalTestgeneratorDSL.g:7894:2: ( rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 )
-            // InternalTestgeneratorDSL.g:7894:3: rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicAssignment_7()); 
+             before(grammarAccess.getLoopAccess().getWithKeyword_9()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getWithKeyword_9()); 
 
             }
 
@@ -24269,26 +24117,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__Loop__Group__9__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:7902:1: rule__ExternalServiceTaskFlowElement__Group__8 : rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__10"
+    // InternalTestgeneratorDSL.g:7935:1: rule__Loop__Group__10 : rule__Loop__Group__10__Impl rule__Loop__Group__11 ;
+    public final void rule__Loop__Group__10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7906:1: ( rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9 )
-            // InternalTestgeneratorDSL.g:7907:2: rule__ExternalServiceTaskFlowElement__Group__8__Impl rule__ExternalServiceTaskFlowElement__Group__9
+            // InternalTestgeneratorDSL.g:7939:1: ( rule__Loop__Group__10__Impl rule__Loop__Group__11 )
+            // InternalTestgeneratorDSL.g:7940:2: rule__Loop__Group__10__Impl rule__Loop__Group__11
             {
-            pushFollow(FOLLOW_26);
-            rule__ExternalServiceTaskFlowElement__Group__8__Impl();
+            pushFollow(FOLLOW_49);
+            rule__Loop__Group__10__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__9();
+            rule__Loop__Group__11();
 
             state._fsp--;
 
@@ -24307,50 +24155,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__8"
+    // $ANTLR end "rule__Loop__Group__10"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:7914:1: rule__ExternalServiceTaskFlowElement__Group__8__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__10__Impl"
+    // InternalTestgeneratorDSL.g:7947:1: rule__Loop__Group__10__Impl : ( ( rule__Loop__EndAssignment_10 ) ) ;
+    public final void rule__Loop__Group__10__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7918:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? ) )
-            // InternalTestgeneratorDSL.g:7919:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? )
+            // InternalTestgeneratorDSL.g:7951:1: ( ( ( rule__Loop__EndAssignment_10 ) ) )
+            // InternalTestgeneratorDSL.g:7952:1: ( ( rule__Loop__EndAssignment_10 ) )
             {
-            // InternalTestgeneratorDSL.g:7919:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8__0 )? )
-            // InternalTestgeneratorDSL.g:7920:2: ( rule__ExternalServiceTaskFlowElement__Group_8__0 )?
+            // InternalTestgeneratorDSL.g:7952:1: ( ( rule__Loop__EndAssignment_10 ) )
+            // InternalTestgeneratorDSL.g:7953:2: ( rule__Loop__EndAssignment_10 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); 
-            // InternalTestgeneratorDSL.g:7921:2: ( rule__ExternalServiceTaskFlowElement__Group_8__0 )?
-            int alt60=2;
-            int LA60_0 = input.LA(1);
-
-            if ( (LA60_0==28) ) {
-                int LA60_1 = input.LA(2);
-
-                if ( (LA60_1==36) ) {
-                    alt60=1;
-                }
-            }
-            switch (alt60) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:7921:3: rule__ExternalServiceTaskFlowElement__Group_8__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_8__0();
-
-                    state._fsp--;
+             before(grammarAccess.getLoopAccess().getEndAssignment_10()); 
+            // InternalTestgeneratorDSL.g:7954:2: ( rule__Loop__EndAssignment_10 )
+            // InternalTestgeneratorDSL.g:7954:3: rule__Loop__EndAssignment_10
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__EndAssignment_10();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8()); 
+             after(grammarAccess.getLoopAccess().getEndAssignment_10()); 
 
             }
 
@@ -24369,26 +24202,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__8__Impl"
+    // $ANTLR end "rule__Loop__Group__10__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__9"
-    // InternalTestgeneratorDSL.g:7929:1: rule__ExternalServiceTaskFlowElement__Group__9 : rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__9() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__11"
+    // InternalTestgeneratorDSL.g:7962:1: rule__Loop__Group__11 : rule__Loop__Group__11__Impl rule__Loop__Group__12 ;
+    public final void rule__Loop__Group__11() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7933:1: ( rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10 )
-            // InternalTestgeneratorDSL.g:7934:2: rule__ExternalServiceTaskFlowElement__Group__9__Impl rule__ExternalServiceTaskFlowElement__Group__10
+            // InternalTestgeneratorDSL.g:7966:1: ( rule__Loop__Group__11__Impl rule__Loop__Group__12 )
+            // InternalTestgeneratorDSL.g:7967:2: rule__Loop__Group__11__Impl rule__Loop__Group__12
             {
-            pushFollow(FOLLOW_26);
-            rule__ExternalServiceTaskFlowElement__Group__9__Impl();
+            pushFollow(FOLLOW_50);
+            rule__Loop__Group__11__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__10();
+            rule__Loop__Group__12();
 
             state._fsp--;
 
@@ -24407,50 +24240,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__9"
+    // $ANTLR end "rule__Loop__Group__11"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:7941:1: rule__ExternalServiceTaskFlowElement__Group__9__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__9__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__11__Impl"
+    // InternalTestgeneratorDSL.g:7974:1: rule__Loop__Group__11__Impl : ( 'has' ) ;
+    public final void rule__Loop__Group__11__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7945:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? ) )
-            // InternalTestgeneratorDSL.g:7946:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? )
+            // InternalTestgeneratorDSL.g:7978:1: ( ( 'has' ) )
+            // InternalTestgeneratorDSL.g:7979:1: ( 'has' )
             {
-            // InternalTestgeneratorDSL.g:7946:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9__0 )? )
-            // InternalTestgeneratorDSL.g:7947:2: ( rule__ExternalServiceTaskFlowElement__Group_9__0 )?
+            // InternalTestgeneratorDSL.g:7979:1: ( 'has' )
+            // InternalTestgeneratorDSL.g:7980:2: 'has'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); 
-            // InternalTestgeneratorDSL.g:7948:2: ( rule__ExternalServiceTaskFlowElement__Group_9__0 )?
-            int alt61=2;
-            int LA61_0 = input.LA(1);
-
-            if ( (LA61_0==28) ) {
-                int LA61_1 = input.LA(2);
-
-                if ( (LA61_1==41) ) {
-                    alt61=1;
-                }
-            }
-            switch (alt61) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:7948:3: rule__ExternalServiceTaskFlowElement__Group_9__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_9__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9()); 
+             before(grammarAccess.getLoopAccess().getHasKeyword_11()); 
+            match(input,64,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getHasKeyword_11()); 
 
             }
 
@@ -24469,26 +24277,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__9__Impl"
+    // $ANTLR end "rule__Loop__Group__11__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__10"
-    // InternalTestgeneratorDSL.g:7956:1: rule__ExternalServiceTaskFlowElement__Group__10 : rule__ExternalServiceTaskFlowElement__Group__10__Impl rule__ExternalServiceTaskFlowElement__Group__11 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__10() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__12"
+    // InternalTestgeneratorDSL.g:7989:1: rule__Loop__Group__12 : rule__Loop__Group__12__Impl rule__Loop__Group__13 ;
+    public final void rule__Loop__Group__12() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7960:1: ( rule__ExternalServiceTaskFlowElement__Group__10__Impl rule__ExternalServiceTaskFlowElement__Group__11 )
-            // InternalTestgeneratorDSL.g:7961:2: rule__ExternalServiceTaskFlowElement__Group__10__Impl rule__ExternalServiceTaskFlowElement__Group__11
+            // InternalTestgeneratorDSL.g:7993:1: ( rule__Loop__Group__12__Impl rule__Loop__Group__13 )
+            // InternalTestgeneratorDSL.g:7994:2: rule__Loop__Group__12__Impl rule__Loop__Group__13
             {
-            pushFollow(FOLLOW_26);
-            rule__ExternalServiceTaskFlowElement__Group__10__Impl();
+            pushFollow(FOLLOW_42);
+            rule__Loop__Group__12__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__11();
+            rule__Loop__Group__13();
 
             state._fsp--;
 
@@ -24507,46 +24315,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__10"
+    // $ANTLR end "rule__Loop__Group__12"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__10__Impl"
-    // InternalTestgeneratorDSL.g:7968:1: rule__ExternalServiceTaskFlowElement__Group__10__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_10__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__10__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__12__Impl"
+    // InternalTestgeneratorDSL.g:8001:1: rule__Loop__Group__12__Impl : ( 'complexity' ) ;
+    public final void rule__Loop__Group__12__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7972:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_10__0 )? ) )
-            // InternalTestgeneratorDSL.g:7973:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10__0 )? )
+            // InternalTestgeneratorDSL.g:8005:1: ( ( 'complexity' ) )
+            // InternalTestgeneratorDSL.g:8006:1: ( 'complexity' )
             {
-            // InternalTestgeneratorDSL.g:7973:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10__0 )? )
-            // InternalTestgeneratorDSL.g:7974:2: ( rule__ExternalServiceTaskFlowElement__Group_10__0 )?
+            // InternalTestgeneratorDSL.g:8006:1: ( 'complexity' )
+            // InternalTestgeneratorDSL.g:8007:2: 'complexity'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10()); 
-            // InternalTestgeneratorDSL.g:7975:2: ( rule__ExternalServiceTaskFlowElement__Group_10__0 )?
-            int alt62=2;
-            int LA62_0 = input.LA(1);
-
-            if ( (LA62_0==28) ) {
-                alt62=1;
-            }
-            switch (alt62) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:7975:3: rule__ExternalServiceTaskFlowElement__Group_10__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_10__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10()); 
+             before(grammarAccess.getLoopAccess().getComplexityKeyword_12()); 
+            match(input,65,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getComplexityKeyword_12()); 
 
             }
 
@@ -24565,26 +24352,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__10__Impl"
+    // $ANTLR end "rule__Loop__Group__12__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__11"
-    // InternalTestgeneratorDSL.g:7983:1: rule__ExternalServiceTaskFlowElement__Group__11 : rule__ExternalServiceTaskFlowElement__Group__11__Impl rule__ExternalServiceTaskFlowElement__Group__12 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__11() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__13"
+    // InternalTestgeneratorDSL.g:8016:1: rule__Loop__Group__13 : rule__Loop__Group__13__Impl rule__Loop__Group__14 ;
+    public final void rule__Loop__Group__13() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7987:1: ( rule__ExternalServiceTaskFlowElement__Group__11__Impl rule__ExternalServiceTaskFlowElement__Group__12 )
-            // InternalTestgeneratorDSL.g:7988:2: rule__ExternalServiceTaskFlowElement__Group__11__Impl rule__ExternalServiceTaskFlowElement__Group__12
+            // InternalTestgeneratorDSL.g:8020:1: ( rule__Loop__Group__13__Impl rule__Loop__Group__14 )
+            // InternalTestgeneratorDSL.g:8021:2: rule__Loop__Group__13__Impl rule__Loop__Group__14
             {
-            pushFollow(FOLLOW_26);
-            rule__ExternalServiceTaskFlowElement__Group__11__Impl();
+            pushFollow(FOLLOW_51);
+            rule__Loop__Group__13__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__12();
+            rule__Loop__Group__14();
 
             state._fsp--;
 
@@ -24603,46 +24390,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__11"
+    // $ANTLR end "rule__Loop__Group__13"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__11__Impl"
-    // InternalTestgeneratorDSL.g:7995:1: rule__ExternalServiceTaskFlowElement__Group__11__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_11__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__11__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__13__Impl"
+    // InternalTestgeneratorDSL.g:8028:1: rule__Loop__Group__13__Impl : ( ( rule__Loop__ComplexityAssignment_13 ) ) ;
+    public final void rule__Loop__Group__13__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:7999:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_11__0 )? ) )
-            // InternalTestgeneratorDSL.g:8000:1: ( ( rule__ExternalServiceTaskFlowElement__Group_11__0 )? )
+            // InternalTestgeneratorDSL.g:8032:1: ( ( ( rule__Loop__ComplexityAssignment_13 ) ) )
+            // InternalTestgeneratorDSL.g:8033:1: ( ( rule__Loop__ComplexityAssignment_13 ) )
             {
-            // InternalTestgeneratorDSL.g:8000:1: ( ( rule__ExternalServiceTaskFlowElement__Group_11__0 )? )
-            // InternalTestgeneratorDSL.g:8001:2: ( rule__ExternalServiceTaskFlowElement__Group_11__0 )?
+            // InternalTestgeneratorDSL.g:8033:1: ( ( rule__Loop__ComplexityAssignment_13 ) )
+            // InternalTestgeneratorDSL.g:8034:2: ( rule__Loop__ComplexityAssignment_13 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_11()); 
-            // InternalTestgeneratorDSL.g:8002:2: ( rule__ExternalServiceTaskFlowElement__Group_11__0 )?
-            int alt63=2;
-            int LA63_0 = input.LA(1);
-
-            if ( (LA63_0==43) ) {
-                alt63=1;
-            }
-            switch (alt63) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:8002:3: rule__ExternalServiceTaskFlowElement__Group_11__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_11__0();
-
-                    state._fsp--;
+             before(grammarAccess.getLoopAccess().getComplexityAssignment_13()); 
+            // InternalTestgeneratorDSL.g:8035:2: ( rule__Loop__ComplexityAssignment_13 )
+            // InternalTestgeneratorDSL.g:8035:3: rule__Loop__ComplexityAssignment_13
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__ComplexityAssignment_13();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_11()); 
+             after(grammarAccess.getLoopAccess().getComplexityAssignment_13()); 
 
             }
 
@@ -24661,21 +24437,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__11__Impl"
+    // $ANTLR end "rule__Loop__Group__13__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__12"
-    // InternalTestgeneratorDSL.g:8010:1: rule__ExternalServiceTaskFlowElement__Group__12 : rule__ExternalServiceTaskFlowElement__Group__12__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__12() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__14"
+    // InternalTestgeneratorDSL.g:8043:1: rule__Loop__Group__14 : rule__Loop__Group__14__Impl rule__Loop__Group__15 ;
+    public final void rule__Loop__Group__14() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8014:1: ( rule__ExternalServiceTaskFlowElement__Group__12__Impl )
-            // InternalTestgeneratorDSL.g:8015:2: rule__ExternalServiceTaskFlowElement__Group__12__Impl
+            // InternalTestgeneratorDSL.g:8047:1: ( rule__Loop__Group__14__Impl rule__Loop__Group__15 )
+            // InternalTestgeneratorDSL.g:8048:2: rule__Loop__Group__14__Impl rule__Loop__Group__15
             {
+            pushFollow(FOLLOW_12);
+            rule__Loop__Group__14__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group__12__Impl();
+            rule__Loop__Group__15();
 
             state._fsp--;
 
@@ -24694,25 +24475,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__12"
+    // $ANTLR end "rule__Loop__Group__14"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group__12__Impl"
-    // InternalTestgeneratorDSL.g:8021:1: rule__ExternalServiceTaskFlowElement__Group__12__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group__12__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__14__Impl"
+    // InternalTestgeneratorDSL.g:8055:1: rule__Loop__Group__14__Impl : ( 'passed' ) ;
+    public final void rule__Loop__Group__14__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8025:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:8026:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:8059:1: ( ( 'passed' ) )
+            // InternalTestgeneratorDSL.g:8060:1: ( 'passed' )
             {
-            // InternalTestgeneratorDSL.g:8026:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:8027:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:8060:1: ( 'passed' )
+            // InternalTestgeneratorDSL.g:8061:2: 'passed'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
+             before(grammarAccess.getLoopAccess().getPassedKeyword_14()); 
+            match(input,66,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getPassedKeyword_14()); 
 
             }
 
@@ -24731,26 +24512,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group__12__Impl"
+    // $ANTLR end "rule__Loop__Group__14__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__0"
-    // InternalTestgeneratorDSL.g:8037:1: rule__ExternalServiceTaskFlowElement__Group_8__0 : rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__0() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__15"
+    // InternalTestgeneratorDSL.g:8070:1: rule__Loop__Group__15 : rule__Loop__Group__15__Impl rule__Loop__Group__16 ;
+    public final void rule__Loop__Group__15() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8041:1: ( rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1 )
-            // InternalTestgeneratorDSL.g:8042:2: rule__ExternalServiceTaskFlowElement__Group_8__0__Impl rule__ExternalServiceTaskFlowElement__Group_8__1
+            // InternalTestgeneratorDSL.g:8074:1: ( rule__Loop__Group__15__Impl rule__Loop__Group__16 )
+            // InternalTestgeneratorDSL.g:8075:2: rule__Loop__Group__15__Impl rule__Loop__Group__16
             {
-            pushFollow(FOLLOW_19);
-            rule__ExternalServiceTaskFlowElement__Group_8__0__Impl();
+            pushFollow(FOLLOW_13);
+            rule__Loop__Group__15__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__1();
+            rule__Loop__Group__16();
 
             state._fsp--;
 
@@ -24769,25 +24550,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__0"
+    // $ANTLR end "rule__Loop__Group__15"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__0__Impl"
-    // InternalTestgeneratorDSL.g:8049:1: rule__ExternalServiceTaskFlowElement__Group_8__0__Impl : ( 'with' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__15__Impl"
+    // InternalTestgeneratorDSL.g:8082:1: rule__Loop__Group__15__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__Loop__Group__15__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8053:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:8054:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:8086:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:8087:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:8054:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:8055:2: 'with'
+            // InternalTestgeneratorDSL.g:8087:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8088:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0()); 
+             before(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); 
 
             }
 
@@ -24806,26 +24587,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__0__Impl"
+    // $ANTLR end "rule__Loop__Group__15__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__1"
-    // InternalTestgeneratorDSL.g:8064:1: rule__ExternalServiceTaskFlowElement__Group_8__1 : rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__1() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__16"
+    // InternalTestgeneratorDSL.g:8097:1: rule__Loop__Group__16 : rule__Loop__Group__16__Impl rule__Loop__Group__17 ;
+    public final void rule__Loop__Group__16() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8068:1: ( rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2 )
-            // InternalTestgeneratorDSL.g:8069:2: rule__ExternalServiceTaskFlowElement__Group_8__1__Impl rule__ExternalServiceTaskFlowElement__Group_8__2
+            // InternalTestgeneratorDSL.g:8101:1: ( rule__Loop__Group__16__Impl rule__Loop__Group__17 )
+            // InternalTestgeneratorDSL.g:8102:2: rule__Loop__Group__16__Impl rule__Loop__Group__17
             {
-            pushFollow(FOLLOW_20);
-            rule__ExternalServiceTaskFlowElement__Group_8__1__Impl();
+            pushFollow(FOLLOW_41);
+            rule__Loop__Group__16__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__2();
+            rule__Loop__Group__17();
 
             state._fsp--;
 
@@ -24844,25 +24625,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__1"
+    // $ANTLR end "rule__Loop__Group__16"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__1__Impl"
-    // InternalTestgeneratorDSL.g:8076:1: rule__ExternalServiceTaskFlowElement__Group_8__1__Impl : ( 'hardcoded' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__16__Impl"
+    // InternalTestgeneratorDSL.g:8109:1: rule__Loop__Group__16__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__Loop__Group__16__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8080:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:8081:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:8113:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:8114:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:8081:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:8082:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:8114:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8115:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1()); 
+             before(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); 
 
             }
 
@@ -24881,26 +24662,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__1__Impl"
+    // $ANTLR end "rule__Loop__Group__16__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__2"
-    // InternalTestgeneratorDSL.g:8091:1: rule__ExternalServiceTaskFlowElement__Group_8__2 : rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__2() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__17"
+    // InternalTestgeneratorDSL.g:8124:1: rule__Loop__Group__17 : rule__Loop__Group__17__Impl rule__Loop__Group__18 ;
+    public final void rule__Loop__Group__17() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8095:1: ( rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3 )
-            // InternalTestgeneratorDSL.g:8096:2: rule__ExternalServiceTaskFlowElement__Group_8__2__Impl rule__ExternalServiceTaskFlowElement__Group_8__3
+            // InternalTestgeneratorDSL.g:8128:1: ( rule__Loop__Group__17__Impl rule__Loop__Group__18 )
+            // InternalTestgeneratorDSL.g:8129:2: rule__Loop__Group__17__Impl rule__Loop__Group__18
             {
-            pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group_8__2__Impl();
+            pushFollow(FOLLOW_41);
+            rule__Loop__Group__17__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__3();
+            rule__Loop__Group__18();
 
             state._fsp--;
 
@@ -24919,25 +24700,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__2"
+    // $ANTLR end "rule__Loop__Group__17"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__2__Impl"
-    // InternalTestgeneratorDSL.g:8103:1: rule__ExternalServiceTaskFlowElement__Group_8__2__Impl : ( 'inputs' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__17__Impl"
+    // InternalTestgeneratorDSL.g:8136:1: rule__Loop__Group__17__Impl : ( ( rule__Loop__Group_17__0 )? ) ;
+    public final void rule__Loop__Group__17__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8107:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:8108:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:8140:1: ( ( ( rule__Loop__Group_17__0 )? ) )
+            // InternalTestgeneratorDSL.g:8141:1: ( ( rule__Loop__Group_17__0 )? )
             {
-            // InternalTestgeneratorDSL.g:8108:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:8109:2: 'inputs'
+            // InternalTestgeneratorDSL.g:8141:1: ( ( rule__Loop__Group_17__0 )? )
+            // InternalTestgeneratorDSL.g:8142:2: ( rule__Loop__Group_17__0 )?
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2()); 
+             before(grammarAccess.getLoopAccess().getGroup_17()); 
+            // InternalTestgeneratorDSL.g:8143:2: ( rule__Loop__Group_17__0 )?
+            int alt47=2;
+            int LA47_0 = input.LA(1);
+
+            if ( (LA47_0==RULE_INT) ) {
+                alt47=1;
+            }
+            switch (alt47) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:8143:3: rule__Loop__Group_17__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Loop__Group_17__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getLoopAccess().getGroup_17()); 
 
             }
 
@@ -24956,26 +24758,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__2__Impl"
+    // $ANTLR end "rule__Loop__Group__17__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__3"
-    // InternalTestgeneratorDSL.g:8118:1: rule__ExternalServiceTaskFlowElement__Group_8__3 : rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__3() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__18"
+    // InternalTestgeneratorDSL.g:8151:1: rule__Loop__Group__18 : rule__Loop__Group__18__Impl rule__Loop__Group__19 ;
+    public final void rule__Loop__Group__18() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8122:1: ( rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4 )
-            // InternalTestgeneratorDSL.g:8123:2: rule__ExternalServiceTaskFlowElement__Group_8__3__Impl rule__ExternalServiceTaskFlowElement__Group_8__4
+            // InternalTestgeneratorDSL.g:8155:1: ( rule__Loop__Group__18__Impl rule__Loop__Group__19 )
+            // InternalTestgeneratorDSL.g:8156:2: rule__Loop__Group__18__Impl rule__Loop__Group__19
             {
-            pushFollow(FOLLOW_13);
-            rule__ExternalServiceTaskFlowElement__Group_8__3__Impl();
+            pushFollow(FOLLOW_22);
+            rule__Loop__Group__18__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__4();
+            rule__Loop__Group__19();
 
             state._fsp--;
 
@@ -24994,25 +24796,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__3"
+    // $ANTLR end "rule__Loop__Group__18"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__3__Impl"
-    // InternalTestgeneratorDSL.g:8130:1: rule__ExternalServiceTaskFlowElement__Group_8__3__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__18__Impl"
+    // InternalTestgeneratorDSL.g:8163:1: rule__Loop__Group__18__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__Loop__Group__18__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8134:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:8135:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8167:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:8168:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:8135:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:8136:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:8168:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:8169:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3()); 
+             before(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); 
 
             }
 
@@ -25031,26 +24833,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__3__Impl"
+    // $ANTLR end "rule__Loop__Group__18__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__4"
-    // InternalTestgeneratorDSL.g:8145:1: rule__ExternalServiceTaskFlowElement__Group_8__4 : rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__4() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__19"
+    // InternalTestgeneratorDSL.g:8178:1: rule__Loop__Group__19 : rule__Loop__Group__19__Impl ;
+    public final void rule__Loop__Group__19() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8149:1: ( rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5 )
-            // InternalTestgeneratorDSL.g:8150:2: rule__ExternalServiceTaskFlowElement__Group_8__4__Impl rule__ExternalServiceTaskFlowElement__Group_8__5
+            // InternalTestgeneratorDSL.g:8182:1: ( rule__Loop__Group__19__Impl )
+            // InternalTestgeneratorDSL.g:8183:2: rule__Loop__Group__19__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_8__4__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__5();
+            rule__Loop__Group__19__Impl();
 
             state._fsp--;
 
@@ -25069,25 +24866,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__4"
+    // $ANTLR end "rule__Loop__Group__19"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__4__Impl"
-    // InternalTestgeneratorDSL.g:8157:1: rule__ExternalServiceTaskFlowElement__Group_8__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group__19__Impl"
+    // InternalTestgeneratorDSL.g:8189:1: rule__Loop__Group__19__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__Loop__Group__19__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8161:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:8162:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8193:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:8194:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:8162:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:8163:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:8194:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:8195:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4()); 
+             before(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); 
 
             }
 
@@ -25106,26 +24903,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__4__Impl"
+    // $ANTLR end "rule__Loop__Group__19__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__5"
-    // InternalTestgeneratorDSL.g:8172:1: rule__ExternalServiceTaskFlowElement__Group_8__5 : rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__5() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17__0"
+    // InternalTestgeneratorDSL.g:8205:1: rule__Loop__Group_17__0 : rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1 ;
+    public final void rule__Loop__Group_17__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8176:1: ( rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6 )
-            // InternalTestgeneratorDSL.g:8177:2: rule__ExternalServiceTaskFlowElement__Group_8__5__Impl rule__ExternalServiceTaskFlowElement__Group_8__6
+            // InternalTestgeneratorDSL.g:8209:1: ( rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1 )
+            // InternalTestgeneratorDSL.g:8210:2: rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_8__5__Impl();
+            pushFollow(FOLLOW_15);
+            rule__Loop__Group_17__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__6();
+            rule__Loop__Group_17__1();
 
             state._fsp--;
 
@@ -25144,46 +24941,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__5"
+    // $ANTLR end "rule__Loop__Group_17__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__5__Impl"
-    // InternalTestgeneratorDSL.g:8184:1: rule__ExternalServiceTaskFlowElement__Group_8__5__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17__0__Impl"
+    // InternalTestgeneratorDSL.g:8217:1: rule__Loop__Group_17__0__Impl : ( ( rule__Loop__FrequenciesAssignment_17_0 ) ) ;
+    public final void rule__Loop__Group_17__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8188:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:8189:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? )
+            // InternalTestgeneratorDSL.g:8221:1: ( ( ( rule__Loop__FrequenciesAssignment_17_0 ) ) )
+            // InternalTestgeneratorDSL.g:8222:1: ( ( rule__Loop__FrequenciesAssignment_17_0 ) )
             {
-            // InternalTestgeneratorDSL.g:8189:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )? )
-            // InternalTestgeneratorDSL.g:8190:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )?
+            // InternalTestgeneratorDSL.g:8222:1: ( ( rule__Loop__FrequenciesAssignment_17_0 ) )
+            // InternalTestgeneratorDSL.g:8223:2: ( rule__Loop__FrequenciesAssignment_17_0 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); 
-            // InternalTestgeneratorDSL.g:8191:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0 )?
-            int alt64=2;
-            int LA64_0 = input.LA(1);
-
-            if ( (LA64_0==RULE_ID) ) {
-                alt64=1;
-            }
-            switch (alt64) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:8191:3: rule__ExternalServiceTaskFlowElement__Group_8_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_8_5__0();
-
-                    state._fsp--;
+             before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); 
+            // InternalTestgeneratorDSL.g:8224:2: ( rule__Loop__FrequenciesAssignment_17_0 )
+            // InternalTestgeneratorDSL.g:8224:3: rule__Loop__FrequenciesAssignment_17_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__FrequenciesAssignment_17_0();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5()); 
+             after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); 
 
             }
 
@@ -25202,21 +24988,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__5__Impl"
+    // $ANTLR end "rule__Loop__Group_17__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__6"
-    // InternalTestgeneratorDSL.g:8199:1: rule__ExternalServiceTaskFlowElement__Group_8__6 : rule__ExternalServiceTaskFlowElement__Group_8__6__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__6() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17__1"
+    // InternalTestgeneratorDSL.g:8232:1: rule__Loop__Group_17__1 : rule__Loop__Group_17__1__Impl ;
+    public final void rule__Loop__Group_17__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8203:1: ( rule__ExternalServiceTaskFlowElement__Group_8__6__Impl )
-            // InternalTestgeneratorDSL.g:8204:2: rule__ExternalServiceTaskFlowElement__Group_8__6__Impl
+            // InternalTestgeneratorDSL.g:8236:1: ( rule__Loop__Group_17__1__Impl )
+            // InternalTestgeneratorDSL.g:8237:2: rule__Loop__Group_17__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8__6__Impl();
+            rule__Loop__Group_17__1__Impl();
 
             state._fsp--;
 
@@ -25235,25 +25021,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__6"
+    // $ANTLR end "rule__Loop__Group_17__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8__6__Impl"
-    // InternalTestgeneratorDSL.g:8210:1: rule__ExternalServiceTaskFlowElement__Group_8__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17__1__Impl"
+    // InternalTestgeneratorDSL.g:8243:1: rule__Loop__Group_17__1__Impl : ( ( rule__Loop__Group_17_1__0 )* ) ;
+    public final void rule__Loop__Group_17__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8214:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:8215:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:8247:1: ( ( ( rule__Loop__Group_17_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:8248:1: ( ( rule__Loop__Group_17_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:8215:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:8216:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:8248:1: ( ( rule__Loop__Group_17_1__0 )* )
+            // InternalTestgeneratorDSL.g:8249:2: ( rule__Loop__Group_17_1__0 )*
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6()); 
+             before(grammarAccess.getLoopAccess().getGroup_17_1()); 
+            // InternalTestgeneratorDSL.g:8250:2: ( rule__Loop__Group_17_1__0 )*
+            loop48:
+            do {
+                int alt48=2;
+                int LA48_0 = input.LA(1);
+
+                if ( (LA48_0==RULE_SEPARATOR) ) {
+                    alt48=1;
+                }
+
+
+                switch (alt48) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:8250:3: rule__Loop__Group_17_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__Loop__Group_17_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop48;
+                }
+            } while (true);
+
+             after(grammarAccess.getLoopAccess().getGroup_17_1()); 
 
             }
 
@@ -25272,26 +25086,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8__6__Impl"
+    // $ANTLR end "rule__Loop__Group_17__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__0"
-    // InternalTestgeneratorDSL.g:8226:1: rule__ExternalServiceTaskFlowElement__Group_8_5__0 : rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__0() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17_1__0"
+    // InternalTestgeneratorDSL.g:8259:1: rule__Loop__Group_17_1__0 : rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1 ;
+    public final void rule__Loop__Group_17_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8230:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1 )
-            // InternalTestgeneratorDSL.g:8231:2: rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5__1
+            // InternalTestgeneratorDSL.g:8263:1: ( rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1 )
+            // InternalTestgeneratorDSL.g:8264:2: rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1
             {
-            pushFollow(FOLLOW_15);
-            rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl();
+            pushFollow(FOLLOW_42);
+            rule__Loop__Group_17_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8_5__1();
+            rule__Loop__Group_17_1__1();
 
             state._fsp--;
 
@@ -25310,35 +25124,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__0"
+    // $ANTLR end "rule__Loop__Group_17_1__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl"
-    // InternalTestgeneratorDSL.g:8238:1: rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl : ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17_1__0__Impl"
+    // InternalTestgeneratorDSL.g:8271:1: rule__Loop__Group_17_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__Loop__Group_17_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8242:1: ( ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:8243:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:8243:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 ) )
-            // InternalTestgeneratorDSL.g:8244:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 )
+            // InternalTestgeneratorDSL.g:8275:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:8276:1: ( RULE_SEPARATOR )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); 
-            // InternalTestgeneratorDSL.g:8245:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 )
-            // InternalTestgeneratorDSL.g:8245:3: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0
+            // InternalTestgeneratorDSL.g:8276:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:8277:2: RULE_SEPARATOR
             {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_0()); 
+             before(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); 
 
             }
 
@@ -25357,21 +25161,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__0__Impl"
+    // $ANTLR end "rule__Loop__Group_17_1__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__1"
-    // InternalTestgeneratorDSL.g:8253:1: rule__ExternalServiceTaskFlowElement__Group_8_5__1 : rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__1() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17_1__1"
+    // InternalTestgeneratorDSL.g:8286:1: rule__Loop__Group_17_1__1 : rule__Loop__Group_17_1__1__Impl ;
+    public final void rule__Loop__Group_17_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8257:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl )
-            // InternalTestgeneratorDSL.g:8258:2: rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl
+            // InternalTestgeneratorDSL.g:8290:1: ( rule__Loop__Group_17_1__1__Impl )
+            // InternalTestgeneratorDSL.g:8291:2: rule__Loop__Group_17_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl();
+            rule__Loop__Group_17_1__1__Impl();
 
             state._fsp--;
 
@@ -25390,53 +25194,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__1"
+    // $ANTLR end "rule__Loop__Group_17_1__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl"
-    // InternalTestgeneratorDSL.g:8264:1: rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Loop__Group_17_1__1__Impl"
+    // InternalTestgeneratorDSL.g:8297:1: rule__Loop__Group_17_1__1__Impl : ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) ) ;
+    public final void rule__Loop__Group_17_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8268:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:8269:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:8301:1: ( ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:8302:1: ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:8269:1: ( ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:8270:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )*
+            // InternalTestgeneratorDSL.g:8302:1: ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) )
+            // InternalTestgeneratorDSL.g:8303:2: ( rule__Loop__FrequenciesAssignment_17_1_1 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); 
-            // InternalTestgeneratorDSL.g:8271:2: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 )*
-            loop65:
-            do {
-                int alt65=2;
-                int LA65_0 = input.LA(1);
-
-                if ( (LA65_0==RULE_SEPARATOR) ) {
-                    alt65=1;
-                }
-
-
-                switch (alt65) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:8271:3: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ExternalServiceTaskFlowElement__Group_8_5_1__0();
-
-            	    state._fsp--;
+             before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); 
+            // InternalTestgeneratorDSL.g:8304:2: ( rule__Loop__FrequenciesAssignment_17_1_1 )
+            // InternalTestgeneratorDSL.g:8304:3: rule__Loop__FrequenciesAssignment_17_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__Loop__FrequenciesAssignment_17_1_1();
 
+            state._fsp--;
 
-            	    }
-            	    break;
 
-            	default :
-            	    break loop65;
-                }
-            } while (true);
+            }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_8_5_1()); 
+             after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); 
 
             }
 
@@ -25455,26 +25241,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5__1__Impl"
+    // $ANTLR end "rule__Loop__Group_17_1__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0"
-    // InternalTestgeneratorDSL.g:8280:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0 : rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__0"
+    // InternalTestgeneratorDSL.g:8313:1: rule__Flow__Group__0 : rule__Flow__Group__0__Impl rule__Flow__Group__1 ;
+    public final void rule__Flow__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8284:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 )
-            // InternalTestgeneratorDSL.g:8285:2: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_8_5_1__1
+            // InternalTestgeneratorDSL.g:8317:1: ( rule__Flow__Group__0__Impl rule__Flow__Group__1 )
+            // InternalTestgeneratorDSL.g:8318:2: rule__Flow__Group__0__Impl rule__Flow__Group__1
             {
             pushFollow(FOLLOW_4);
-            rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl();
+            rule__Flow__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8_5_1__1();
+            rule__Flow__Group__1();
 
             state._fsp--;
 
@@ -25493,25 +25279,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0"
+    // $ANTLR end "rule__Flow__Group__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:8292:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:8325:1: rule__Flow__Group__0__Impl : ( 'Flow' ) ;
+    public final void rule__Flow__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8296:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:8297:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:8329:1: ( ( 'Flow' ) )
+            // InternalTestgeneratorDSL.g:8330:1: ( 'Flow' )
             {
-            // InternalTestgeneratorDSL.g:8297:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:8298:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:8330:1: ( 'Flow' )
+            // InternalTestgeneratorDSL.g:8331:2: 'Flow'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0()); 
+             before(grammarAccess.getFlowAccess().getFlowKeyword_0()); 
+            match(input,67,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getFlowKeyword_0()); 
 
             }
 
@@ -25530,21 +25316,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__0__Impl"
+    // $ANTLR end "rule__Flow__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1"
-    // InternalTestgeneratorDSL.g:8307:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1 : rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__1"
+    // InternalTestgeneratorDSL.g:8340:1: rule__Flow__Group__1 : rule__Flow__Group__1__Impl rule__Flow__Group__2 ;
+    public final void rule__Flow__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8311:1: ( rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:8312:2: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:8344:1: ( rule__Flow__Group__1__Impl rule__Flow__Group__2 )
+            // InternalTestgeneratorDSL.g:8345:2: rule__Flow__Group__1__Impl rule__Flow__Group__2
             {
+            pushFollow(FOLLOW_52);
+            rule__Flow__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl();
+            rule__Flow__Group__2();
 
             state._fsp--;
 
@@ -25563,35 +25354,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1"
+    // $ANTLR end "rule__Flow__Group__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:8318:1: rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:8352:1: rule__Flow__Group__1__Impl : ( ( rule__Flow__NameAssignment_1 ) ) ;
+    public final void rule__Flow__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8322:1: ( ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:8323:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:8356:1: ( ( ( rule__Flow__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:8357:1: ( ( rule__Flow__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:8323:1: ( ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:8324:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 )
+            // InternalTestgeneratorDSL.g:8357:1: ( ( rule__Flow__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:8358:2: ( rule__Flow__NameAssignment_1 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); 
-            // InternalTestgeneratorDSL.g:8325:2: ( rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 )
-            // InternalTestgeneratorDSL.g:8325:3: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1
+             before(grammarAccess.getFlowAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:8359:2: ( rule__Flow__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:8359:3: rule__Flow__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1();
+            rule__Flow__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsAssignment_8_5_1_1()); 
+             after(grammarAccess.getFlowAccess().getNameAssignment_1()); 
 
             }
 
@@ -25610,26 +25401,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_8_5_1__1__Impl"
+    // $ANTLR end "rule__Flow__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__0"
-    // InternalTestgeneratorDSL.g:8334:1: rule__ExternalServiceTaskFlowElement__Group_9__0 : rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__2"
+    // InternalTestgeneratorDSL.g:8367:1: rule__Flow__Group__2 : rule__Flow__Group__2__Impl rule__Flow__Group__3 ;
+    public final void rule__Flow__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8338:1: ( rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1 )
-            // InternalTestgeneratorDSL.g:8339:2: rule__ExternalServiceTaskFlowElement__Group_9__0__Impl rule__ExternalServiceTaskFlowElement__Group_9__1
+            // InternalTestgeneratorDSL.g:8371:1: ( rule__Flow__Group__2__Impl rule__Flow__Group__3 )
+            // InternalTestgeneratorDSL.g:8372:2: rule__Flow__Group__2__Impl rule__Flow__Group__3
             {
-            pushFollow(FOLLOW_27);
-            rule__ExternalServiceTaskFlowElement__Group_9__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Flow__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__1();
+            rule__Flow__Group__3();
 
             state._fsp--;
 
@@ -25648,25 +25439,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__0"
+    // $ANTLR end "rule__Flow__Group__2"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__0__Impl"
-    // InternalTestgeneratorDSL.g:8346:1: rule__ExternalServiceTaskFlowElement__Group_9__0__Impl : ( 'with' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:8379:1: rule__Flow__Group__2__Impl : ( 'for' ) ;
+    public final void rule__Flow__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8350:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:8351:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:8383:1: ( ( 'for' ) )
+            // InternalTestgeneratorDSL.g:8384:1: ( 'for' )
             {
-            // InternalTestgeneratorDSL.g:8351:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:8352:2: 'with'
+            // InternalTestgeneratorDSL.g:8384:1: ( 'for' )
+            // InternalTestgeneratorDSL.g:8385:2: 'for'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_9_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_9_0()); 
+             before(grammarAccess.getFlowAccess().getForKeyword_2()); 
+            match(input,68,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getForKeyword_2()); 
 
             }
 
@@ -25685,26 +25476,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__0__Impl"
+    // $ANTLR end "rule__Flow__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__1"
-    // InternalTestgeneratorDSL.g:8361:1: rule__ExternalServiceTaskFlowElement__Group_9__1 : rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__3"
+    // InternalTestgeneratorDSL.g:8394:1: rule__Flow__Group__3 : rule__Flow__Group__3__Impl rule__Flow__Group__4 ;
+    public final void rule__Flow__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8365:1: ( rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2 )
-            // InternalTestgeneratorDSL.g:8366:2: rule__ExternalServiceTaskFlowElement__Group_9__1__Impl rule__ExternalServiceTaskFlowElement__Group_9__2
+            // InternalTestgeneratorDSL.g:8398:1: ( rule__Flow__Group__3__Impl rule__Flow__Group__4 )
+            // InternalTestgeneratorDSL.g:8399:2: rule__Flow__Group__3__Impl rule__Flow__Group__4
             {
-            pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group_9__1__Impl();
+            pushFollow(FOLLOW_5);
+            rule__Flow__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__2();
+            rule__Flow__Group__4();
 
             state._fsp--;
 
@@ -25723,25 +25514,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__1"
+    // $ANTLR end "rule__Flow__Group__3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__1__Impl"
-    // InternalTestgeneratorDSL.g:8373:1: rule__ExternalServiceTaskFlowElement__Group_9__1__Impl : ( 'inputVariables' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:8406:1: rule__Flow__Group__3__Impl : ( ( rule__Flow__BpmnReferenceAssignment_3 ) ) ;
+    public final void rule__Flow__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8377:1: ( ( 'inputVariables' ) )
-            // InternalTestgeneratorDSL.g:8378:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:8410:1: ( ( ( rule__Flow__BpmnReferenceAssignment_3 ) ) )
+            // InternalTestgeneratorDSL.g:8411:1: ( ( rule__Flow__BpmnReferenceAssignment_3 ) )
             {
-            // InternalTestgeneratorDSL.g:8378:1: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:8379:2: 'inputVariables'
+            // InternalTestgeneratorDSL.g:8411:1: ( ( rule__Flow__BpmnReferenceAssignment_3 ) )
+            // InternalTestgeneratorDSL.g:8412:2: ( rule__Flow__BpmnReferenceAssignment_3 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesKeyword_9_1()); 
-            match(input,41,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesKeyword_9_1()); 
+             before(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); 
+            // InternalTestgeneratorDSL.g:8413:2: ( rule__Flow__BpmnReferenceAssignment_3 )
+            // InternalTestgeneratorDSL.g:8413:3: rule__Flow__BpmnReferenceAssignment_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__Flow__BpmnReferenceAssignment_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); 
 
             }
 
@@ -25760,26 +25561,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__1__Impl"
+    // $ANTLR end "rule__Flow__Group__3__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__2"
-    // InternalTestgeneratorDSL.g:8388:1: rule__ExternalServiceTaskFlowElement__Group_9__2 : rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__2() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__4"
+    // InternalTestgeneratorDSL.g:8421:1: rule__Flow__Group__4 : rule__Flow__Group__4__Impl rule__Flow__Group__5 ;
+    public final void rule__Flow__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8392:1: ( rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3 )
-            // InternalTestgeneratorDSL.g:8393:2: rule__ExternalServiceTaskFlowElement__Group_9__2__Impl rule__ExternalServiceTaskFlowElement__Group_9__3
+            // InternalTestgeneratorDSL.g:8425:1: ( rule__Flow__Group__4__Impl rule__Flow__Group__5 )
+            // InternalTestgeneratorDSL.g:8426:2: rule__Flow__Group__4__Impl rule__Flow__Group__5
             {
-            pushFollow(FOLLOW_13);
-            rule__ExternalServiceTaskFlowElement__Group_9__2__Impl();
+            pushFollow(FOLLOW_5);
+            rule__Flow__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__3();
+            rule__Flow__Group__5();
 
             state._fsp--;
 
@@ -25798,25 +25599,50 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__2"
+    // $ANTLR end "rule__Flow__Group__4"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__2__Impl"
-    // InternalTestgeneratorDSL.g:8400:1: rule__ExternalServiceTaskFlowElement__Group_9__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:8433:1: rule__Flow__Group__4__Impl : ( ( rule__Flow__Group_4__0 )? ) ;
+    public final void rule__Flow__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8404:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:8405:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8437:1: ( ( ( rule__Flow__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:8438:1: ( ( rule__Flow__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:8405:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:8406:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:8438:1: ( ( rule__Flow__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:8439:2: ( rule__Flow__Group_4__0 )?
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2()); 
+             before(grammarAccess.getFlowAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:8440:2: ( rule__Flow__Group_4__0 )?
+            int alt49=2;
+            int LA49_0 = input.LA(1);
+
+            if ( (LA49_0==29) ) {
+                int LA49_1 = input.LA(2);
+
+                if ( (LA49_1==70) ) {
+                    alt49=1;
+                }
+            }
+            switch (alt49) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:8440:3: rule__Flow__Group_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Flow__Group_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getFlowAccess().getGroup_4()); 
 
             }
 
@@ -25835,26 +25661,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__2__Impl"
+    // $ANTLR end "rule__Flow__Group__4__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__3"
-    // InternalTestgeneratorDSL.g:8415:1: rule__ExternalServiceTaskFlowElement__Group_9__3 : rule__ExternalServiceTaskFlowElement__Group_9__3__Impl rule__ExternalServiceTaskFlowElement__Group_9__4 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__3() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__5"
+    // InternalTestgeneratorDSL.g:8448:1: rule__Flow__Group__5 : rule__Flow__Group__5__Impl rule__Flow__Group__6 ;
+    public final void rule__Flow__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8419:1: ( rule__ExternalServiceTaskFlowElement__Group_9__3__Impl rule__ExternalServiceTaskFlowElement__Group_9__4 )
-            // InternalTestgeneratorDSL.g:8420:2: rule__ExternalServiceTaskFlowElement__Group_9__3__Impl rule__ExternalServiceTaskFlowElement__Group_9__4
+            // InternalTestgeneratorDSL.g:8452:1: ( rule__Flow__Group__5__Impl rule__Flow__Group__6 )
+            // InternalTestgeneratorDSL.g:8453:2: rule__Flow__Group__5__Impl rule__Flow__Group__6
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_9__3__Impl();
+            pushFollow(FOLLOW_53);
+            rule__Flow__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__4();
+            rule__Flow__Group__6();
 
             state._fsp--;
 
@@ -25873,25 +25699,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__3"
+    // $ANTLR end "rule__Flow__Group__5"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__3__Impl"
-    // InternalTestgeneratorDSL.g:8427:1: rule__ExternalServiceTaskFlowElement__Group_9__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:8460:1: rule__Flow__Group__5__Impl : ( 'with' ) ;
+    public final void rule__Flow__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8431:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:8432:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8464:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:8465:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:8432:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:8433:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:8465:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:8466:2: 'with'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_9_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_9_3()); 
+             before(grammarAccess.getFlowAccess().getWithKeyword_5()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getWithKeyword_5()); 
 
             }
 
@@ -25910,26 +25736,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__3__Impl"
+    // $ANTLR end "rule__Flow__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__4"
-    // InternalTestgeneratorDSL.g:8442:1: rule__ExternalServiceTaskFlowElement__Group_9__4 : rule__ExternalServiceTaskFlowElement__Group_9__4__Impl rule__ExternalServiceTaskFlowElement__Group_9__5 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__4() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__6"
+    // InternalTestgeneratorDSL.g:8475:1: rule__Flow__Group__6 : rule__Flow__Group__6__Impl rule__Flow__Group__7 ;
+    public final void rule__Flow__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8446:1: ( rule__ExternalServiceTaskFlowElement__Group_9__4__Impl rule__ExternalServiceTaskFlowElement__Group_9__5 )
-            // InternalTestgeneratorDSL.g:8447:2: rule__ExternalServiceTaskFlowElement__Group_9__4__Impl rule__ExternalServiceTaskFlowElement__Group_9__5
+            // InternalTestgeneratorDSL.g:8479:1: ( rule__Flow__Group__6__Impl rule__Flow__Group__7 )
+            // InternalTestgeneratorDSL.g:8480:2: rule__Flow__Group__6__Impl rule__Flow__Group__7
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_9__4__Impl();
+            pushFollow(FOLLOW_12);
+            rule__Flow__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__5();
+            rule__Flow__Group__7();
 
             state._fsp--;
 
@@ -25948,46 +25774,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__4"
+    // $ANTLR end "rule__Flow__Group__6"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__4__Impl"
-    // InternalTestgeneratorDSL.g:8454:1: rule__ExternalServiceTaskFlowElement__Group_9__4__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:8487:1: rule__Flow__Group__6__Impl : ( 'elements' ) ;
+    public final void rule__Flow__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8458:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:8459:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )? )
+            // InternalTestgeneratorDSL.g:8491:1: ( ( 'elements' ) )
+            // InternalTestgeneratorDSL.g:8492:1: ( 'elements' )
             {
-            // InternalTestgeneratorDSL.g:8459:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )? )
-            // InternalTestgeneratorDSL.g:8460:2: ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )?
+            // InternalTestgeneratorDSL.g:8492:1: ( 'elements' )
+            // InternalTestgeneratorDSL.g:8493:2: 'elements'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4()); 
-            // InternalTestgeneratorDSL.g:8461:2: ( rule__ExternalServiceTaskFlowElement__Group_9_4__0 )?
-            int alt66=2;
-            int LA66_0 = input.LA(1);
-
-            if ( (LA66_0==RULE_ID) ) {
-                alt66=1;
-            }
-            switch (alt66) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:8461:3: rule__ExternalServiceTaskFlowElement__Group_9_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_9_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4()); 
+             before(grammarAccess.getFlowAccess().getElementsKeyword_6()); 
+            match(input,69,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getElementsKeyword_6()); 
 
             }
 
@@ -26006,21 +25811,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__4__Impl"
+    // $ANTLR end "rule__Flow__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__5"
-    // InternalTestgeneratorDSL.g:8469:1: rule__ExternalServiceTaskFlowElement__Group_9__5 : rule__ExternalServiceTaskFlowElement__Group_9__5__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__5() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__7"
+    // InternalTestgeneratorDSL.g:8502:1: rule__Flow__Group__7 : rule__Flow__Group__7__Impl rule__Flow__Group__8 ;
+    public final void rule__Flow__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8473:1: ( rule__ExternalServiceTaskFlowElement__Group_9__5__Impl )
-            // InternalTestgeneratorDSL.g:8474:2: rule__ExternalServiceTaskFlowElement__Group_9__5__Impl
+            // InternalTestgeneratorDSL.g:8506:1: ( rule__Flow__Group__7__Impl rule__Flow__Group__8 )
+            // InternalTestgeneratorDSL.g:8507:2: rule__Flow__Group__7__Impl rule__Flow__Group__8
             {
+            pushFollow(FOLLOW_13);
+            rule__Flow__Group__7__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9__5__Impl();
+            rule__Flow__Group__8();
 
             state._fsp--;
 
@@ -26039,25 +25849,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__5"
+    // $ANTLR end "rule__Flow__Group__7"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9__5__Impl"
-    // InternalTestgeneratorDSL.g:8480:1: rule__ExternalServiceTaskFlowElement__Group_9__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:8514:1: rule__Flow__Group__7__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__Flow__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8484:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:8485:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:8518:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:8519:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:8485:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:8486:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:8519:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8520:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_9_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_9_5()); 
+             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); 
 
             }
 
@@ -26076,26 +25886,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9__5__Impl"
+    // $ANTLR end "rule__Flow__Group__7__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4__0"
-    // InternalTestgeneratorDSL.g:8496:1: rule__ExternalServiceTaskFlowElement__Group_9_4__0 : rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__8"
+    // InternalTestgeneratorDSL.g:8529:1: rule__Flow__Group__8 : rule__Flow__Group__8__Impl rule__Flow__Group__9 ;
+    public final void rule__Flow__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8500:1: ( rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4__1 )
-            // InternalTestgeneratorDSL.g:8501:2: rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4__1
+            // InternalTestgeneratorDSL.g:8533:1: ( rule__Flow__Group__8__Impl rule__Flow__Group__9 )
+            // InternalTestgeneratorDSL.g:8534:2: rule__Flow__Group__8__Impl rule__Flow__Group__9
             {
-            pushFollow(FOLLOW_15);
-            rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl();
+            pushFollow(FOLLOW_20);
+            rule__Flow__Group__8__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9_4__1();
+            rule__Flow__Group__9();
 
             state._fsp--;
 
@@ -26114,35 +25924,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4__0"
+    // $ANTLR end "rule__Flow__Group__8"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl"
-    // InternalTestgeneratorDSL.g:8508:1: rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl : ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:8541:1: rule__Flow__Group__8__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__Flow__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8512:1: ( ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:8513:1: ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 ) )
+            // InternalTestgeneratorDSL.g:8545:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:8546:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:8513:1: ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 ) )
-            // InternalTestgeneratorDSL.g:8514:2: ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 )
+            // InternalTestgeneratorDSL.g:8546:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8547:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_0()); 
-            // InternalTestgeneratorDSL.g:8515:2: ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 )
-            // InternalTestgeneratorDSL.g:8515:3: rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_0()); 
+             before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); 
 
             }
 
@@ -26161,21 +25961,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4__0__Impl"
+    // $ANTLR end "rule__Flow__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4__1"
-    // InternalTestgeneratorDSL.g:8523:1: rule__ExternalServiceTaskFlowElement__Group_9_4__1 : rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__9"
+    // InternalTestgeneratorDSL.g:8556:1: rule__Flow__Group__9 : rule__Flow__Group__9__Impl rule__Flow__Group__10 ;
+    public final void rule__Flow__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8527:1: ( rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl )
-            // InternalTestgeneratorDSL.g:8528:2: rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl
+            // InternalTestgeneratorDSL.g:8560:1: ( rule__Flow__Group__9__Impl rule__Flow__Group__10 )
+            // InternalTestgeneratorDSL.g:8561:2: rule__Flow__Group__9__Impl rule__Flow__Group__10
             {
+            pushFollow(FOLLOW_20);
+            rule__Flow__Group__9__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl();
+            rule__Flow__Group__10();
 
             state._fsp--;
 
@@ -26194,53 +25999,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4__1"
+    // $ANTLR end "rule__Flow__Group__9"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl"
-    // InternalTestgeneratorDSL.g:8534:1: rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )* ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__9__Impl"
+    // InternalTestgeneratorDSL.g:8568:1: rule__Flow__Group__9__Impl : ( ( rule__Flow__Group_9__0 )? ) ;
+    public final void rule__Flow__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8538:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:8539:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:8572:1: ( ( ( rule__Flow__Group_9__0 )? ) )
+            // InternalTestgeneratorDSL.g:8573:1: ( ( rule__Flow__Group_9__0 )? )
             {
-            // InternalTestgeneratorDSL.g:8539:1: ( ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:8540:2: ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )*
+            // InternalTestgeneratorDSL.g:8573:1: ( ( rule__Flow__Group_9__0 )? )
+            // InternalTestgeneratorDSL.g:8574:2: ( rule__Flow__Group_9__0 )?
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4_1()); 
-            // InternalTestgeneratorDSL.g:8541:2: ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 )*
-            loop67:
-            do {
-                int alt67=2;
-                int LA67_0 = input.LA(1);
-
-                if ( (LA67_0==RULE_SEPARATOR) ) {
-                    alt67=1;
-                }
-
+             before(grammarAccess.getFlowAccess().getGroup_9()); 
+            // InternalTestgeneratorDSL.g:8575:2: ( rule__Flow__Group_9__0 )?
+            int alt50=2;
+            int LA50_0 = input.LA(1);
 
-                switch (alt67) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:8541:3: rule__ExternalServiceTaskFlowElement__Group_9_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ExternalServiceTaskFlowElement__Group_9_4_1__0();
+            if ( (LA50_0==RULE_ID) ) {
+                alt50=1;
+            }
+            switch (alt50) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:8575:3: rule__Flow__Group_9__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Flow__Group_9__0();
 
-            	    state._fsp--;
+                    state._fsp--;
 
 
-            	    }
-            	    break;
+                    }
+                    break;
 
-            	default :
-            	    break loop67;
-                }
-            } while (true);
+            }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_9_4_1()); 
+             after(grammarAccess.getFlowAccess().getGroup_9()); 
 
             }
 
@@ -26259,26 +26057,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4__1__Impl"
+    // $ANTLR end "rule__Flow__Group__9__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4_1__0"
-    // InternalTestgeneratorDSL.g:8550:1: rule__ExternalServiceTaskFlowElement__Group_9_4_1__0 : rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4_1__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__10"
+    // InternalTestgeneratorDSL.g:8583:1: rule__Flow__Group__10 : rule__Flow__Group__10__Impl rule__Flow__Group__11 ;
+    public final void rule__Flow__Group__10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8554:1: ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4_1__1 )
-            // InternalTestgeneratorDSL.g:8555:2: rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_9_4_1__1
+            // InternalTestgeneratorDSL.g:8587:1: ( rule__Flow__Group__10__Impl rule__Flow__Group__11 )
+            // InternalTestgeneratorDSL.g:8588:2: rule__Flow__Group__10__Impl rule__Flow__Group__11
             {
-            pushFollow(FOLLOW_4);
-            rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl();
+            pushFollow(FOLLOW_54);
+            rule__Flow__Group__10__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9_4_1__1();
+            rule__Flow__Group__11();
 
             state._fsp--;
 
@@ -26297,25 +26095,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4_1__0"
+    // $ANTLR end "rule__Flow__Group__10"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:8562:1: rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__10__Impl"
+    // InternalTestgeneratorDSL.g:8595:1: rule__Flow__Group__10__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__Flow__Group__10__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8566:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:8567:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:8599:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:8600:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:8567:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:8568:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:8600:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:8601:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_9_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_9_4_1_0()); 
+             before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
 
             }
 
@@ -26334,21 +26132,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4_1__0__Impl"
+    // $ANTLR end "rule__Flow__Group__10__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4_1__1"
-    // InternalTestgeneratorDSL.g:8577:1: rule__ExternalServiceTaskFlowElement__Group_9_4_1__1 : rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__11"
+    // InternalTestgeneratorDSL.g:8610:1: rule__Flow__Group__11 : rule__Flow__Group__11__Impl rule__Flow__Group__12 ;
+    public final void rule__Flow__Group__11() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8581:1: ( rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:8582:2: rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:8614:1: ( rule__Flow__Group__11__Impl rule__Flow__Group__12 )
+            // InternalTestgeneratorDSL.g:8615:2: rule__Flow__Group__11__Impl rule__Flow__Group__12
             {
+            pushFollow(FOLLOW_54);
+            rule__Flow__Group__11__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl();
+            rule__Flow__Group__12();
 
             state._fsp--;
 
@@ -26367,35 +26170,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4_1__1"
+    // $ANTLR end "rule__Flow__Group__11"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:8588:1: rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__11__Impl"
+    // InternalTestgeneratorDSL.g:8622:1: rule__Flow__Group__11__Impl : ( ( rule__Flow__Group_11__0 )? ) ;
+    public final void rule__Flow__Group__11__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8592:1: ( ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:8593:1: ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:8593:1: ( ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:8594:2: ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 )
+            // InternalTestgeneratorDSL.g:8626:1: ( ( ( rule__Flow__Group_11__0 )? ) )
+            // InternalTestgeneratorDSL.g:8627:1: ( ( rule__Flow__Group_11__0 )? )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_1_1()); 
-            // InternalTestgeneratorDSL.g:8595:2: ( rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 )
-            // InternalTestgeneratorDSL.g:8595:3: rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1
+            // InternalTestgeneratorDSL.g:8627:1: ( ( rule__Flow__Group_11__0 )? )
+            // InternalTestgeneratorDSL.g:8628:2: ( rule__Flow__Group_11__0 )?
             {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1();
+             before(grammarAccess.getFlowAccess().getGroup_11()); 
+            // InternalTestgeneratorDSL.g:8629:2: ( rule__Flow__Group_11__0 )?
+            int alt51=2;
+            int LA51_0 = input.LA(1);
 
-            state._fsp--;
+            if ( (LA51_0==71) ) {
+                alt51=1;
+            }
+            switch (alt51) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:8629:3: rule__Flow__Group_11__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Flow__Group_11__0();
+
+                    state._fsp--;
 
 
+                    }
+                    break;
+
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesAssignment_9_4_1_1()); 
+             after(grammarAccess.getFlowAccess().getGroup_11()); 
 
             }
 
@@ -26414,26 +26228,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_9_4_1__1__Impl"
+    // $ANTLR end "rule__Flow__Group__11__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__0"
-    // InternalTestgeneratorDSL.g:8604:1: rule__ExternalServiceTaskFlowElement__Group_10__0 : rule__ExternalServiceTaskFlowElement__Group_10__0__Impl rule__ExternalServiceTaskFlowElement__Group_10__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__12"
+    // InternalTestgeneratorDSL.g:8637:1: rule__Flow__Group__12 : rule__Flow__Group__12__Impl ;
+    public final void rule__Flow__Group__12() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8608:1: ( rule__ExternalServiceTaskFlowElement__Group_10__0__Impl rule__ExternalServiceTaskFlowElement__Group_10__1 )
-            // InternalTestgeneratorDSL.g:8609:2: rule__ExternalServiceTaskFlowElement__Group_10__0__Impl rule__ExternalServiceTaskFlowElement__Group_10__1
+            // InternalTestgeneratorDSL.g:8641:1: ( rule__Flow__Group__12__Impl )
+            // InternalTestgeneratorDSL.g:8642:2: rule__Flow__Group__12__Impl
             {
-            pushFollow(FOLLOW_28);
-            rule__ExternalServiceTaskFlowElement__Group_10__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__1();
+            rule__Flow__Group__12__Impl();
 
             state._fsp--;
 
@@ -26452,25 +26261,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__0"
+    // $ANTLR end "rule__Flow__Group__12"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__0__Impl"
-    // InternalTestgeneratorDSL.g:8616:1: rule__ExternalServiceTaskFlowElement__Group_10__0__Impl : ( 'with' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group__12__Impl"
+    // InternalTestgeneratorDSL.g:8648:1: rule__Flow__Group__12__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__Flow__Group__12__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8620:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:8621:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:8652:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:8653:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:8621:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:8622:2: 'with'
+            // InternalTestgeneratorDSL.g:8653:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:8654:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_10_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_10_0()); 
+             before(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
 
             }
 
@@ -26489,26 +26298,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__0__Impl"
+    // $ANTLR end "rule__Flow__Group__12__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__1"
-    // InternalTestgeneratorDSL.g:8631:1: rule__ExternalServiceTaskFlowElement__Group_10__1 : rule__ExternalServiceTaskFlowElement__Group_10__1__Impl rule__ExternalServiceTaskFlowElement__Group_10__2 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__0"
+    // InternalTestgeneratorDSL.g:8664:1: rule__Flow__Group_4__0 : rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1 ;
+    public final void rule__Flow__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8635:1: ( rule__ExternalServiceTaskFlowElement__Group_10__1__Impl rule__ExternalServiceTaskFlowElement__Group_10__2 )
-            // InternalTestgeneratorDSL.g:8636:2: rule__ExternalServiceTaskFlowElement__Group_10__1__Impl rule__ExternalServiceTaskFlowElement__Group_10__2
+            // InternalTestgeneratorDSL.g:8668:1: ( rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1 )
+            // InternalTestgeneratorDSL.g:8669:2: rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1
             {
-            pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group_10__1__Impl();
+            pushFollow(FOLLOW_55);
+            rule__Flow__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__2();
+            rule__Flow__Group_4__1();
 
             state._fsp--;
 
@@ -26527,25 +26336,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__1"
+    // $ANTLR end "rule__Flow__Group_4__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__1__Impl"
-    // InternalTestgeneratorDSL.g:8643:1: rule__ExternalServiceTaskFlowElement__Group_10__1__Impl : ( 'outputVariables' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:8676:1: rule__Flow__Group_4__0__Impl : ( 'with' ) ;
+    public final void rule__Flow__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8647:1: ( ( 'outputVariables' ) )
-            // InternalTestgeneratorDSL.g:8648:1: ( 'outputVariables' )
+            // InternalTestgeneratorDSL.g:8680:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:8681:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:8648:1: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:8649:2: 'outputVariables'
+            // InternalTestgeneratorDSL.g:8681:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:8682:2: 'with'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesKeyword_10_1()); 
-            match(input,42,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesKeyword_10_1()); 
+             before(grammarAccess.getFlowAccess().getWithKeyword_4_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getWithKeyword_4_0()); 
 
             }
 
@@ -26564,26 +26373,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__1__Impl"
+    // $ANTLR end "rule__Flow__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__2"
-    // InternalTestgeneratorDSL.g:8658:1: rule__ExternalServiceTaskFlowElement__Group_10__2 : rule__ExternalServiceTaskFlowElement__Group_10__2__Impl rule__ExternalServiceTaskFlowElement__Group_10__3 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__2() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__1"
+    // InternalTestgeneratorDSL.g:8691:1: rule__Flow__Group_4__1 : rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2 ;
+    public final void rule__Flow__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8662:1: ( rule__ExternalServiceTaskFlowElement__Group_10__2__Impl rule__ExternalServiceTaskFlowElement__Group_10__3 )
-            // InternalTestgeneratorDSL.g:8663:2: rule__ExternalServiceTaskFlowElement__Group_10__2__Impl rule__ExternalServiceTaskFlowElement__Group_10__3
+            // InternalTestgeneratorDSL.g:8695:1: ( rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2 )
+            // InternalTestgeneratorDSL.g:8696:2: rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2
             {
-            pushFollow(FOLLOW_13);
-            rule__ExternalServiceTaskFlowElement__Group_10__2__Impl();
+            pushFollow(FOLLOW_12);
+            rule__Flow__Group_4__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__3();
+            rule__Flow__Group_4__2();
 
             state._fsp--;
 
@@ -26602,25 +26411,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__2"
+    // $ANTLR end "rule__Flow__Group_4__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__2__Impl"
-    // InternalTestgeneratorDSL.g:8670:1: rule__ExternalServiceTaskFlowElement__Group_10__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:8703:1: rule__Flow__Group_4__1__Impl : ( 'flag' ) ;
+    public final void rule__Flow__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8674:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:8675:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8707:1: ( ( 'flag' ) )
+            // InternalTestgeneratorDSL.g:8708:1: ( 'flag' )
             {
-            // InternalTestgeneratorDSL.g:8675:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:8676:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:8708:1: ( 'flag' )
+            // InternalTestgeneratorDSL.g:8709:2: 'flag'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_10_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_10_2()); 
+             before(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); 
+            match(input,70,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); 
 
             }
 
@@ -26639,26 +26448,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__2__Impl"
+    // $ANTLR end "rule__Flow__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__3"
-    // InternalTestgeneratorDSL.g:8685:1: rule__ExternalServiceTaskFlowElement__Group_10__3 : rule__ExternalServiceTaskFlowElement__Group_10__3__Impl rule__ExternalServiceTaskFlowElement__Group_10__4 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__3() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__2"
+    // InternalTestgeneratorDSL.g:8718:1: rule__Flow__Group_4__2 : rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3 ;
+    public final void rule__Flow__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8689:1: ( rule__ExternalServiceTaskFlowElement__Group_10__3__Impl rule__ExternalServiceTaskFlowElement__Group_10__4 )
-            // InternalTestgeneratorDSL.g:8690:2: rule__ExternalServiceTaskFlowElement__Group_10__3__Impl rule__ExternalServiceTaskFlowElement__Group_10__4
+            // InternalTestgeneratorDSL.g:8722:1: ( rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3 )
+            // InternalTestgeneratorDSL.g:8723:2: rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_10__3__Impl();
+            pushFollow(FOLLOW_39);
+            rule__Flow__Group_4__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__4();
+            rule__Flow__Group_4__3();
 
             state._fsp--;
 
@@ -26677,25 +26486,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__3"
+    // $ANTLR end "rule__Flow__Group_4__2"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__3__Impl"
-    // InternalTestgeneratorDSL.g:8697:1: rule__ExternalServiceTaskFlowElement__Group_10__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:8730:1: rule__Flow__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__Flow__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8701:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:8702:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8734:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:8735:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:8702:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:8703:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:8735:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8736:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_10_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_10_3()); 
+             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
 
             }
 
@@ -26714,26 +26523,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__3__Impl"
+    // $ANTLR end "rule__Flow__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__4"
-    // InternalTestgeneratorDSL.g:8712:1: rule__ExternalServiceTaskFlowElement__Group_10__4 : rule__ExternalServiceTaskFlowElement__Group_10__4__Impl rule__ExternalServiceTaskFlowElement__Group_10__5 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__4() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__3"
+    // InternalTestgeneratorDSL.g:8745:1: rule__Flow__Group_4__3 : rule__Flow__Group_4__3__Impl ;
+    public final void rule__Flow__Group_4__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8716:1: ( rule__ExternalServiceTaskFlowElement__Group_10__4__Impl rule__ExternalServiceTaskFlowElement__Group_10__5 )
-            // InternalTestgeneratorDSL.g:8717:2: rule__ExternalServiceTaskFlowElement__Group_10__4__Impl rule__ExternalServiceTaskFlowElement__Group_10__5
+            // InternalTestgeneratorDSL.g:8749:1: ( rule__Flow__Group_4__3__Impl )
+            // InternalTestgeneratorDSL.g:8750:2: rule__Flow__Group_4__3__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__ExternalServiceTaskFlowElement__Group_10__4__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__5();
+            rule__Flow__Group_4__3__Impl();
 
             state._fsp--;
 
@@ -26752,116 +26556,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__4"
+    // $ANTLR end "rule__Flow__Group_4__3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__4__Impl"
-    // InternalTestgeneratorDSL.g:8724:1: rule__ExternalServiceTaskFlowElement__Group_10__4__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )? ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_4__3__Impl"
+    // InternalTestgeneratorDSL.g:8756:1: rule__Flow__Group_4__3__Impl : ( ( rule__Flow__FlagAssignment_4_3 ) ) ;
+    public final void rule__Flow__Group_4__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8728:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:8729:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )? )
+            // InternalTestgeneratorDSL.g:8760:1: ( ( ( rule__Flow__FlagAssignment_4_3 ) ) )
+            // InternalTestgeneratorDSL.g:8761:1: ( ( rule__Flow__FlagAssignment_4_3 ) )
             {
-            // InternalTestgeneratorDSL.g:8729:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )? )
-            // InternalTestgeneratorDSL.g:8730:2: ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )?
+            // InternalTestgeneratorDSL.g:8761:1: ( ( rule__Flow__FlagAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:8762:2: ( rule__Flow__FlagAssignment_4_3 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4()); 
-            // InternalTestgeneratorDSL.g:8731:2: ( rule__ExternalServiceTaskFlowElement__Group_10_4__0 )?
-            int alt68=2;
-            int LA68_0 = input.LA(1);
-
-            if ( (LA68_0==RULE_ID) ) {
-                alt68=1;
-            }
-            switch (alt68) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:8731:3: rule__ExternalServiceTaskFlowElement__Group_10_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceTaskFlowElement__Group_10_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__4__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__5"
-    // InternalTestgeneratorDSL.g:8739:1: rule__ExternalServiceTaskFlowElement__Group_10__5 : rule__ExternalServiceTaskFlowElement__Group_10__5__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:8743:1: ( rule__ExternalServiceTaskFlowElement__Group_10__5__Impl )
-            // InternalTestgeneratorDSL.g:8744:2: rule__ExternalServiceTaskFlowElement__Group_10__5__Impl
+             before(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); 
+            // InternalTestgeneratorDSL.g:8763:2: ( rule__Flow__FlagAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:8763:3: rule__Flow__FlagAssignment_4_3
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10__5__Impl();
+            rule__Flow__FlagAssignment_4_3();
 
             state._fsp--;
 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__5"
-
-
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10__5__Impl"
-    // InternalTestgeneratorDSL.g:8750:1: rule__ExternalServiceTaskFlowElement__Group_10__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:8754:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:8755:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:8755:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:8756:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_10_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_10_5()); 
+             after(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); 
 
             }
 
@@ -26880,26 +26603,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10__5__Impl"
+    // $ANTLR end "rule__Flow__Group_4__3__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4__0"
-    // InternalTestgeneratorDSL.g:8766:1: rule__ExternalServiceTaskFlowElement__Group_10_4__0 : rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9__0"
+    // InternalTestgeneratorDSL.g:8772:1: rule__Flow__Group_9__0 : rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1 ;
+    public final void rule__Flow__Group_9__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8770:1: ( rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4__1 )
-            // InternalTestgeneratorDSL.g:8771:2: rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4__1
+            // InternalTestgeneratorDSL.g:8776:1: ( rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1 )
+            // InternalTestgeneratorDSL.g:8777:2: rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1
             {
             pushFollow(FOLLOW_15);
-            rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl();
+            rule__Flow__Group_9__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10_4__1();
+            rule__Flow__Group_9__1();
 
             state._fsp--;
 
@@ -26918,35 +26641,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4__0"
+    // $ANTLR end "rule__Flow__Group_9__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl"
-    // InternalTestgeneratorDSL.g:8778:1: rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl : ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9__0__Impl"
+    // InternalTestgeneratorDSL.g:8784:1: rule__Flow__Group_9__0__Impl : ( ( rule__Flow__InclElementsAssignment_9_0 ) ) ;
+    public final void rule__Flow__Group_9__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8782:1: ( ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:8783:1: ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 ) )
+            // InternalTestgeneratorDSL.g:8788:1: ( ( ( rule__Flow__InclElementsAssignment_9_0 ) ) )
+            // InternalTestgeneratorDSL.g:8789:1: ( ( rule__Flow__InclElementsAssignment_9_0 ) )
             {
-            // InternalTestgeneratorDSL.g:8783:1: ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 ) )
-            // InternalTestgeneratorDSL.g:8784:2: ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 )
+            // InternalTestgeneratorDSL.g:8789:1: ( ( rule__Flow__InclElementsAssignment_9_0 ) )
+            // InternalTestgeneratorDSL.g:8790:2: ( rule__Flow__InclElementsAssignment_9_0 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_0()); 
-            // InternalTestgeneratorDSL.g:8785:2: ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 )
-            // InternalTestgeneratorDSL.g:8785:3: rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0
+             before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); 
+            // InternalTestgeneratorDSL.g:8791:2: ( rule__Flow__InclElementsAssignment_9_0 )
+            // InternalTestgeneratorDSL.g:8791:3: rule__Flow__InclElementsAssignment_9_0
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0();
+            rule__Flow__InclElementsAssignment_9_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_0()); 
+             after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); 
 
             }
 
@@ -26965,21 +26688,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4__0__Impl"
+    // $ANTLR end "rule__Flow__Group_9__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4__1"
-    // InternalTestgeneratorDSL.g:8793:1: rule__ExternalServiceTaskFlowElement__Group_10_4__1 : rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9__1"
+    // InternalTestgeneratorDSL.g:8799:1: rule__Flow__Group_9__1 : rule__Flow__Group_9__1__Impl ;
+    public final void rule__Flow__Group_9__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8797:1: ( rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl )
-            // InternalTestgeneratorDSL.g:8798:2: rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl
+            // InternalTestgeneratorDSL.g:8803:1: ( rule__Flow__Group_9__1__Impl )
+            // InternalTestgeneratorDSL.g:8804:2: rule__Flow__Group_9__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl();
+            rule__Flow__Group_9__1__Impl();
 
             state._fsp--;
 
@@ -26998,40 +26721,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4__1"
+    // $ANTLR end "rule__Flow__Group_9__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl"
-    // InternalTestgeneratorDSL.g:8804:1: rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )* ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9__1__Impl"
+    // InternalTestgeneratorDSL.g:8810:1: rule__Flow__Group_9__1__Impl : ( ( rule__Flow__Group_9_1__0 )* ) ;
+    public final void rule__Flow__Group_9__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8808:1: ( ( ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:8809:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:8814:1: ( ( ( rule__Flow__Group_9_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:8815:1: ( ( rule__Flow__Group_9_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:8809:1: ( ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:8810:2: ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )*
+            // InternalTestgeneratorDSL.g:8815:1: ( ( rule__Flow__Group_9_1__0 )* )
+            // InternalTestgeneratorDSL.g:8816:2: ( rule__Flow__Group_9_1__0 )*
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4_1()); 
-            // InternalTestgeneratorDSL.g:8811:2: ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 )*
-            loop69:
+             before(grammarAccess.getFlowAccess().getGroup_9_1()); 
+            // InternalTestgeneratorDSL.g:8817:2: ( rule__Flow__Group_9_1__0 )*
+            loop52:
             do {
-                int alt69=2;
-                int LA69_0 = input.LA(1);
+                int alt52=2;
+                int LA52_0 = input.LA(1);
 
-                if ( (LA69_0==RULE_SEPARATOR) ) {
-                    alt69=1;
+                if ( (LA52_0==RULE_SEPARATOR) ) {
+                    alt52=1;
                 }
 
 
-                switch (alt69) {
+                switch (alt52) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:8811:3: rule__ExternalServiceTaskFlowElement__Group_10_4_1__0
+            	    // InternalTestgeneratorDSL.g:8817:3: rule__Flow__Group_9_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__ExternalServiceTaskFlowElement__Group_10_4_1__0();
+            	    rule__Flow__Group_9_1__0();
 
             	    state._fsp--;
 
@@ -27040,11 +26763,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop69;
+            	    break loop52;
                 }
             } while (true);
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getGroup_10_4_1()); 
+             after(grammarAccess.getFlowAccess().getGroup_9_1()); 
 
             }
 
@@ -27063,26 +26786,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4__1__Impl"
+    // $ANTLR end "rule__Flow__Group_9__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4_1__0"
-    // InternalTestgeneratorDSL.g:8820:1: rule__ExternalServiceTaskFlowElement__Group_10_4_1__0 : rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4_1__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9_1__0"
+    // InternalTestgeneratorDSL.g:8826:1: rule__Flow__Group_9_1__0 : rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1 ;
+    public final void rule__Flow__Group_9_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8824:1: ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4_1__1 )
-            // InternalTestgeneratorDSL.g:8825:2: rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl rule__ExternalServiceTaskFlowElement__Group_10_4_1__1
+            // InternalTestgeneratorDSL.g:8830:1: ( rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1 )
+            // InternalTestgeneratorDSL.g:8831:2: rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1
             {
             pushFollow(FOLLOW_4);
-            rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl();
+            rule__Flow__Group_9_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10_4_1__1();
+            rule__Flow__Group_9_1__1();
 
             state._fsp--;
 
@@ -27101,25 +26824,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4_1__0"
+    // $ANTLR end "rule__Flow__Group_9_1__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:8832:1: rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9_1__0__Impl"
+    // InternalTestgeneratorDSL.g:8838:1: rule__Flow__Group_9_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__Flow__Group_9_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8836:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:8837:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:8842:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:8843:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:8837:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:8838:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:8843:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:8844:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_10_4_1_0()); 
+             before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_10_4_1_0()); 
+             after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
 
             }
 
@@ -27138,21 +26861,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4_1__0__Impl"
+    // $ANTLR end "rule__Flow__Group_9_1__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4_1__1"
-    // InternalTestgeneratorDSL.g:8847:1: rule__ExternalServiceTaskFlowElement__Group_10_4_1__1 : rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9_1__1"
+    // InternalTestgeneratorDSL.g:8853:1: rule__Flow__Group_9_1__1 : rule__Flow__Group_9_1__1__Impl ;
+    public final void rule__Flow__Group_9_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8851:1: ( rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:8852:2: rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:8857:1: ( rule__Flow__Group_9_1__1__Impl )
+            // InternalTestgeneratorDSL.g:8858:2: rule__Flow__Group_9_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl();
+            rule__Flow__Group_9_1__1__Impl();
 
             state._fsp--;
 
@@ -27171,35 +26894,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4_1__1"
+    // $ANTLR end "rule__Flow__Group_9_1__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:8858:1: rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl : ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_9_1__1__Impl"
+    // InternalTestgeneratorDSL.g:8864:1: rule__Flow__Group_9_1__1__Impl : ( ( rule__Flow__InclElementsAssignment_9_1_1 ) ) ;
+    public final void rule__Flow__Group_9_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8862:1: ( ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:8863:1: ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:8868:1: ( ( ( rule__Flow__InclElementsAssignment_9_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:8869:1: ( ( rule__Flow__InclElementsAssignment_9_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:8863:1: ( ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:8864:2: ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 )
+            // InternalTestgeneratorDSL.g:8869:1: ( ( rule__Flow__InclElementsAssignment_9_1_1 ) )
+            // InternalTestgeneratorDSL.g:8870:2: ( rule__Flow__InclElementsAssignment_9_1_1 )
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_1_1()); 
-            // InternalTestgeneratorDSL.g:8865:2: ( rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 )
-            // InternalTestgeneratorDSL.g:8865:3: rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1
+             before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); 
+            // InternalTestgeneratorDSL.g:8871:2: ( rule__Flow__InclElementsAssignment_9_1_1 )
+            // InternalTestgeneratorDSL.g:8871:3: rule__Flow__InclElementsAssignment_9_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1();
+            rule__Flow__InclElementsAssignment_9_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesAssignment_10_4_1_1()); 
+             after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); 
 
             }
 
@@ -27218,26 +26941,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_10_4_1__1__Impl"
+    // $ANTLR end "rule__Flow__Group_9_1__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__0"
-    // InternalTestgeneratorDSL.g:8874:1: rule__ExternalServiceTaskFlowElement__Group_11__0 : rule__ExternalServiceTaskFlowElement__Group_11__0__Impl rule__ExternalServiceTaskFlowElement__Group_11__1 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__0"
+    // InternalTestgeneratorDSL.g:8880:1: rule__Flow__Group_11__0 : rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1 ;
+    public final void rule__Flow__Group_11__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8878:1: ( rule__ExternalServiceTaskFlowElement__Group_11__0__Impl rule__ExternalServiceTaskFlowElement__Group_11__1 )
-            // InternalTestgeneratorDSL.g:8879:2: rule__ExternalServiceTaskFlowElement__Group_11__0__Impl rule__ExternalServiceTaskFlowElement__Group_11__1
+            // InternalTestgeneratorDSL.g:8884:1: ( rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1 )
+            // InternalTestgeneratorDSL.g:8885:2: rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1
             {
-            pushFollow(FOLLOW_29);
-            rule__ExternalServiceTaskFlowElement__Group_11__0__Impl();
+            pushFollow(FOLLOW_53);
+            rule__Flow__Group_11__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_11__1();
+            rule__Flow__Group_11__1();
 
             state._fsp--;
 
@@ -27256,25 +26979,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__0"
+    // $ANTLR end "rule__Flow__Group_11__0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__0__Impl"
-    // InternalTestgeneratorDSL.g:8886:1: rule__ExternalServiceTaskFlowElement__Group_11__0__Impl : ( 'and' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__0__Impl"
+    // InternalTestgeneratorDSL.g:8892:1: rule__Flow__Group_11__0__Impl : ( 'without' ) ;
+    public final void rule__Flow__Group_11__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8890:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:8891:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:8896:1: ( ( 'without' ) )
+            // InternalTestgeneratorDSL.g:8897:1: ( 'without' )
             {
-            // InternalTestgeneratorDSL.g:8891:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:8892:2: 'and'
+            // InternalTestgeneratorDSL.g:8897:1: ( 'without' )
+            // InternalTestgeneratorDSL.g:8898:2: 'without'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_11_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_11_0()); 
+             before(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); 
+            match(input,71,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); 
 
             }
 
@@ -27293,26 +27016,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__0__Impl"
+    // $ANTLR end "rule__Flow__Group_11__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__1"
-    // InternalTestgeneratorDSL.g:8901:1: rule__ExternalServiceTaskFlowElement__Group_11__1 : rule__ExternalServiceTaskFlowElement__Group_11__1__Impl rule__ExternalServiceTaskFlowElement__Group_11__2 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__1"
+    // InternalTestgeneratorDSL.g:8907:1: rule__Flow__Group_11__1 : rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2 ;
+    public final void rule__Flow__Group_11__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8905:1: ( rule__ExternalServiceTaskFlowElement__Group_11__1__Impl rule__ExternalServiceTaskFlowElement__Group_11__2 )
-            // InternalTestgeneratorDSL.g:8906:2: rule__ExternalServiceTaskFlowElement__Group_11__1__Impl rule__ExternalServiceTaskFlowElement__Group_11__2
+            // InternalTestgeneratorDSL.g:8911:1: ( rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2 )
+            // InternalTestgeneratorDSL.g:8912:2: rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2
             {
             pushFollow(FOLLOW_12);
-            rule__ExternalServiceTaskFlowElement__Group_11__1__Impl();
+            rule__Flow__Group_11__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_11__2();
+            rule__Flow__Group_11__2();
 
             state._fsp--;
 
@@ -27331,25 +27054,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__1"
+    // $ANTLR end "rule__Flow__Group_11__1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__1__Impl"
-    // InternalTestgeneratorDSL.g:8913:1: rule__ExternalServiceTaskFlowElement__Group_11__1__Impl : ( 'label' ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__1__Impl"
+    // InternalTestgeneratorDSL.g:8919:1: rule__Flow__Group_11__1__Impl : ( 'elements' ) ;
+    public final void rule__Flow__Group_11__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8917:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:8918:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:8923:1: ( ( 'elements' ) )
+            // InternalTestgeneratorDSL.g:8924:1: ( 'elements' )
             {
-            // InternalTestgeneratorDSL.g:8918:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:8919:2: 'label'
+            // InternalTestgeneratorDSL.g:8924:1: ( 'elements' )
+            // InternalTestgeneratorDSL.g:8925:2: 'elements'
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_11_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_11_1()); 
+             before(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); 
+            match(input,69,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); 
 
             }
 
@@ -27368,26 +27091,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__1__Impl"
+    // $ANTLR end "rule__Flow__Group_11__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__2"
-    // InternalTestgeneratorDSL.g:8928:1: rule__ExternalServiceTaskFlowElement__Group_11__2 : rule__ExternalServiceTaskFlowElement__Group_11__2__Impl rule__ExternalServiceTaskFlowElement__Group_11__3 ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__2() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__2"
+    // InternalTestgeneratorDSL.g:8934:1: rule__Flow__Group_11__2 : rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3 ;
+    public final void rule__Flow__Group_11__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8932:1: ( rule__ExternalServiceTaskFlowElement__Group_11__2__Impl rule__ExternalServiceTaskFlowElement__Group_11__3 )
-            // InternalTestgeneratorDSL.g:8933:2: rule__ExternalServiceTaskFlowElement__Group_11__2__Impl rule__ExternalServiceTaskFlowElement__Group_11__3
+            // InternalTestgeneratorDSL.g:8938:1: ( rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3 )
+            // InternalTestgeneratorDSL.g:8939:2: rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3
             {
-            pushFollow(FOLLOW_7);
-            rule__ExternalServiceTaskFlowElement__Group_11__2__Impl();
+            pushFollow(FOLLOW_13);
+            rule__Flow__Group_11__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_11__3();
+            rule__Flow__Group_11__3();
 
             state._fsp--;
 
@@ -27406,25 +27129,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__2"
+    // $ANTLR end "rule__Flow__Group_11__2"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__2__Impl"
-    // InternalTestgeneratorDSL.g:8940:1: rule__ExternalServiceTaskFlowElement__Group_11__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__2__Impl"
+    // InternalTestgeneratorDSL.g:8946:1: rule__Flow__Group_11__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__Flow__Group_11__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8944:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:8945:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8950:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:8951:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:8945:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:8946:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:8951:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:8952:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
+             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
+             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
 
             }
 
@@ -27443,21 +27166,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__2__Impl"
+    // $ANTLR end "rule__Flow__Group_11__2__Impl"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__3"
-    // InternalTestgeneratorDSL.g:8955:1: rule__ExternalServiceTaskFlowElement__Group_11__3 : rule__ExternalServiceTaskFlowElement__Group_11__3__Impl ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__3() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__3"
+    // InternalTestgeneratorDSL.g:8961:1: rule__Flow__Group_11__3 : rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4 ;
+    public final void rule__Flow__Group_11__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8959:1: ( rule__ExternalServiceTaskFlowElement__Group_11__3__Impl )
-            // InternalTestgeneratorDSL.g:8960:2: rule__ExternalServiceTaskFlowElement__Group_11__3__Impl
+            // InternalTestgeneratorDSL.g:8965:1: ( rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4 )
+            // InternalTestgeneratorDSL.g:8966:2: rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4
             {
+            pushFollow(FOLLOW_20);
+            rule__Flow__Group_11__3__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__Group_11__3__Impl();
+            rule__Flow__Group_11__4();
 
             state._fsp--;
 
@@ -27476,35 +27204,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__3"
+    // $ANTLR end "rule__Flow__Group_11__3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__Group_11__3__Impl"
-    // InternalTestgeneratorDSL.g:8966:1: rule__ExternalServiceTaskFlowElement__Group_11__3__Impl : ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 ) ) ;
-    public final void rule__ExternalServiceTaskFlowElement__Group_11__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__3__Impl"
+    // InternalTestgeneratorDSL.g:8973:1: rule__Flow__Group_11__3__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__Flow__Group_11__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8970:1: ( ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 ) ) )
-            // InternalTestgeneratorDSL.g:8971:1: ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 ) )
+            // InternalTestgeneratorDSL.g:8977:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:8978:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:8971:1: ( ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 ) )
-            // InternalTestgeneratorDSL.g:8972:2: ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 )
+            // InternalTestgeneratorDSL.g:8978:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:8979:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_11_3()); 
-            // InternalTestgeneratorDSL.g:8973:2: ( rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 )
-            // InternalTestgeneratorDSL.g:8973:3: rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelAssignment_11_3()); 
+             before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); 
 
             }
 
@@ -27523,26 +27241,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__Group_11__3__Impl"
+    // $ANTLR end "rule__Flow__Group_11__3__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:8982:1: rule__BusinessRuleTaskFlowElement__Group__0 : rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__4"
+    // InternalTestgeneratorDSL.g:8988:1: rule__Flow__Group_11__4 : rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5 ;
+    public final void rule__Flow__Group_11__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8986:1: ( rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:8987:2: rule__BusinessRuleTaskFlowElement__Group__0__Impl rule__BusinessRuleTaskFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:8992:1: ( rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5 )
+            // InternalTestgeneratorDSL.g:8993:2: rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5
             {
-            pushFollow(FOLLOW_4);
-            rule__BusinessRuleTaskFlowElement__Group__0__Impl();
+            pushFollow(FOLLOW_20);
+            rule__Flow__Group_11__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__1();
+            rule__Flow__Group_11__5();
 
             state._fsp--;
 
@@ -27561,25 +27279,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__0"
+    // $ANTLR end "rule__Flow__Group_11__4"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:8994:1: rule__BusinessRuleTaskFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__4__Impl"
+    // InternalTestgeneratorDSL.g:9000:1: rule__Flow__Group_11__4__Impl : ( ( rule__Flow__Group_11_4__0 )? ) ;
+    public final void rule__Flow__Group_11__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:8998:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:8999:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:9004:1: ( ( ( rule__Flow__Group_11_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:9005:1: ( ( rule__Flow__Group_11_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:8999:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:9000:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:9005:1: ( ( rule__Flow__Group_11_4__0 )? )
+            // InternalTestgeneratorDSL.g:9006:2: ( rule__Flow__Group_11_4__0 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getFlowAccess().getGroup_11_4()); 
+            // InternalTestgeneratorDSL.g:9007:2: ( rule__Flow__Group_11_4__0 )?
+            int alt53=2;
+            int LA53_0 = input.LA(1);
+
+            if ( (LA53_0==RULE_ID) ) {
+                alt53=1;
+            }
+            switch (alt53) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9007:3: rule__Flow__Group_11_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Flow__Group_11_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getFlowAccess().getGroup_11_4()); 
 
             }
 
@@ -27598,26 +27337,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__Flow__Group_11__4__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:9009:1: rule__BusinessRuleTaskFlowElement__Group__1 : rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__5"
+    // InternalTestgeneratorDSL.g:9015:1: rule__Flow__Group_11__5 : rule__Flow__Group_11__5__Impl ;
+    public final void rule__Flow__Group_11__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9013:1: ( rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:9014:2: rule__BusinessRuleTaskFlowElement__Group__1__Impl rule__BusinessRuleTaskFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:9019:1: ( rule__Flow__Group_11__5__Impl )
+            // InternalTestgeneratorDSL.g:9020:2: rule__Flow__Group_11__5__Impl
             {
-            pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__2();
+            rule__Flow__Group_11__5__Impl();
 
             state._fsp--;
 
@@ -27636,35 +27370,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__1"
+    // $ANTLR end "rule__Flow__Group_11__5"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:9021:1: rule__BusinessRuleTaskFlowElement__Group__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11__5__Impl"
+    // InternalTestgeneratorDSL.g:9026:1: rule__Flow__Group_11__5__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__Flow__Group_11__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9025:1: ( ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:9026:1: ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:9030:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:9031:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:9026:1: ( ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:9027:2: ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:9031:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:9032:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:9028:2: ( rule__BusinessRuleTaskFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:9028:3: rule__BusinessRuleTaskFlowElement__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); 
 
             }
 
@@ -27683,26 +27407,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__Flow__Group_11__5__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:9036:1: rule__BusinessRuleTaskFlowElement__Group__2 : rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4__0"
+    // InternalTestgeneratorDSL.g:9042:1: rule__Flow__Group_11_4__0 : rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1 ;
+    public final void rule__Flow__Group_11_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9040:1: ( rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:9041:2: rule__BusinessRuleTaskFlowElement__Group__2__Impl rule__BusinessRuleTaskFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:9046:1: ( rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1 )
+            // InternalTestgeneratorDSL.g:9047:2: rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1
             {
-            pushFollow(FOLLOW_36);
-            rule__BusinessRuleTaskFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_15);
+            rule__Flow__Group_11_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__3();
+            rule__Flow__Group_11_4__1();
 
             state._fsp--;
 
@@ -27721,25 +27445,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__2"
+    // $ANTLR end "rule__Flow__Group_11_4__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:9048:1: rule__BusinessRuleTaskFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4__0__Impl"
+    // InternalTestgeneratorDSL.g:9054:1: rule__Flow__Group_11_4__0__Impl : ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) ) ;
+    public final void rule__Flow__Group_11_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9052:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:9053:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9058:1: ( ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:9059:1: ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:9053:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:9054:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:9059:1: ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) )
+            // InternalTestgeneratorDSL.g:9060:2: ( rule__Flow__ExclElementsAssignment_11_4_0 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); 
+            // InternalTestgeneratorDSL.g:9061:2: ( rule__Flow__ExclElementsAssignment_11_4_0 )
+            // InternalTestgeneratorDSL.g:9061:3: rule__Flow__ExclElementsAssignment_11_4_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__Flow__ExclElementsAssignment_11_4_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); 
 
             }
 
@@ -27758,26 +27492,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__Flow__Group_11_4__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:9063:1: rule__BusinessRuleTaskFlowElement__Group__3 : rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4__1"
+    // InternalTestgeneratorDSL.g:9069:1: rule__Flow__Group_11_4__1 : rule__Flow__Group_11_4__1__Impl ;
+    public final void rule__Flow__Group_11_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9067:1: ( rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:9068:2: rule__BusinessRuleTaskFlowElement__Group__3__Impl rule__BusinessRuleTaskFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:9073:1: ( rule__Flow__Group_11_4__1__Impl )
+            // InternalTestgeneratorDSL.g:9074:2: rule__Flow__Group_11_4__1__Impl
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__4();
+            rule__Flow__Group_11_4__1__Impl();
 
             state._fsp--;
 
@@ -27796,25 +27525,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__3"
+    // $ANTLR end "rule__Flow__Group_11_4__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:9075:1: rule__BusinessRuleTaskFlowElement__Group__3__Impl : ( 'BusinessRuleTask' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4__1__Impl"
+    // InternalTestgeneratorDSL.g:9080:1: rule__Flow__Group_11_4__1__Impl : ( ( rule__Flow__Group_11_4_1__0 )* ) ;
+    public final void rule__Flow__Group_11_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9079:1: ( ( 'BusinessRuleTask' ) )
-            // InternalTestgeneratorDSL.g:9080:1: ( 'BusinessRuleTask' )
+            // InternalTestgeneratorDSL.g:9084:1: ( ( ( rule__Flow__Group_11_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:9085:1: ( ( rule__Flow__Group_11_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:9080:1: ( 'BusinessRuleTask' )
-            // InternalTestgeneratorDSL.g:9081:2: 'BusinessRuleTask'
+            // InternalTestgeneratorDSL.g:9085:1: ( ( rule__Flow__Group_11_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:9086:2: ( rule__Flow__Group_11_4_1__0 )*
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); 
-            match(input,50,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3()); 
+             before(grammarAccess.getFlowAccess().getGroup_11_4_1()); 
+            // InternalTestgeneratorDSL.g:9087:2: ( rule__Flow__Group_11_4_1__0 )*
+            loop54:
+            do {
+                int alt54=2;
+                int LA54_0 = input.LA(1);
+
+                if ( (LA54_0==RULE_SEPARATOR) ) {
+                    alt54=1;
+                }
+
+
+                switch (alt54) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:9087:3: rule__Flow__Group_11_4_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__Flow__Group_11_4_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop54;
+                }
+            } while (true);
+
+             after(grammarAccess.getFlowAccess().getGroup_11_4_1()); 
 
             }
 
@@ -27833,26 +27590,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__Flow__Group_11_4__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:9090:1: rule__BusinessRuleTaskFlowElement__Group__4 : rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4_1__0"
+    // InternalTestgeneratorDSL.g:9096:1: rule__Flow__Group_11_4_1__0 : rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1 ;
+    public final void rule__Flow__Group_11_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9094:1: ( rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:9095:2: rule__BusinessRuleTaskFlowElement__Group__4__Impl rule__BusinessRuleTaskFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:9100:1: ( rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1 )
+            // InternalTestgeneratorDSL.g:9101:2: rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Flow__Group_11_4_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__5();
+            rule__Flow__Group_11_4_1__1();
 
             state._fsp--;
 
@@ -27871,50 +27628,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__4"
+    // $ANTLR end "rule__Flow__Group_11_4_1__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:9102:1: rule__BusinessRuleTaskFlowElement__Group__4__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4_1__0__Impl"
+    // InternalTestgeneratorDSL.g:9108:1: rule__Flow__Group_11_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__Flow__Group_11_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9106:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:9107:1: ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:9112:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:9113:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:9107:1: ( ( rule__BusinessRuleTaskFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:9108:2: ( rule__BusinessRuleTaskFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:9113:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:9114:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:9109:2: ( rule__BusinessRuleTaskFlowElement__Group_4__0 )?
-            int alt70=2;
-            int LA70_0 = input.LA(1);
-
-            if ( (LA70_0==28) ) {
-                int LA70_1 = input.LA(2);
-
-                if ( (LA70_1==51) ) {
-                    alt70=1;
-                }
-            }
-            switch (alt70) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9109:3: rule__BusinessRuleTaskFlowElement__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_4()); 
+             before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); 
 
             }
 
@@ -27933,26 +27665,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__Flow__Group_11_4_1__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:9117:1: rule__BusinessRuleTaskFlowElement__Group__5 : rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4_1__1"
+    // InternalTestgeneratorDSL.g:9123:1: rule__Flow__Group_11_4_1__1 : rule__Flow__Group_11_4_1__1__Impl ;
+    public final void rule__Flow__Group_11_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9121:1: ( rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6 )
-            // InternalTestgeneratorDSL.g:9122:2: rule__BusinessRuleTaskFlowElement__Group__5__Impl rule__BusinessRuleTaskFlowElement__Group__6
+            // InternalTestgeneratorDSL.g:9127:1: ( rule__Flow__Group_11_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:9128:2: rule__Flow__Group_11_4_1__1__Impl
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__6();
+            rule__Flow__Group_11_4_1__1__Impl();
 
             state._fsp--;
 
@@ -27971,50 +27698,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__5"
+    // $ANTLR end "rule__Flow__Group_11_4_1__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:9129:1: rule__BusinessRuleTaskFlowElement__Group__5__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Flow__Group_11_4_1__1__Impl"
+    // InternalTestgeneratorDSL.g:9134:1: rule__Flow__Group_11_4_1__1__Impl : ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) ) ;
+    public final void rule__Flow__Group_11_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9133:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:9134:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:9138:1: ( ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:9139:1: ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:9134:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:9135:2: ( rule__BusinessRuleTaskFlowElement__Group_5__0 )?
+            // InternalTestgeneratorDSL.g:9139:1: ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:9140:2: ( rule__Flow__ExclElementsAssignment_11_4_1_1 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:9136:2: ( rule__BusinessRuleTaskFlowElement__Group_5__0 )?
-            int alt71=2;
-            int LA71_0 = input.LA(1);
-
-            if ( (LA71_0==28) ) {
-                int LA71_1 = input.LA(2);
-
-                if ( (LA71_1==36) ) {
-                    alt71=1;
-                }
-            }
-            switch (alt71) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9136:3: rule__BusinessRuleTaskFlowElement__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_5__0();
-
-                    state._fsp--;
+             before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); 
+            // InternalTestgeneratorDSL.g:9141:2: ( rule__Flow__ExclElementsAssignment_11_4_1_1 )
+            // InternalTestgeneratorDSL.g:9141:3: rule__Flow__ExclElementsAssignment_11_4_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__Flow__ExclElementsAssignment_11_4_1_1();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5()); 
+             after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); 
 
             }
 
@@ -28033,26 +27745,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__Flow__Group_11_4_1__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__6"
-    // InternalTestgeneratorDSL.g:9144:1: rule__BusinessRuleTaskFlowElement__Group__6 : rule__BusinessRuleTaskFlowElement__Group__6__Impl rule__BusinessRuleTaskFlowElement__Group__7 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__0"
+    // InternalTestgeneratorDSL.g:9150:1: rule__Test__Group__0 : rule__Test__Group__0__Impl rule__Test__Group__1 ;
+    public final void rule__Test__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9148:1: ( rule__BusinessRuleTaskFlowElement__Group__6__Impl rule__BusinessRuleTaskFlowElement__Group__7 )
-            // InternalTestgeneratorDSL.g:9149:2: rule__BusinessRuleTaskFlowElement__Group__6__Impl rule__BusinessRuleTaskFlowElement__Group__7
+            // InternalTestgeneratorDSL.g:9154:1: ( rule__Test__Group__0__Impl rule__Test__Group__1 )
+            // InternalTestgeneratorDSL.g:9155:2: rule__Test__Group__0__Impl rule__Test__Group__1
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__6__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Test__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__7();
+            rule__Test__Group__1();
 
             state._fsp--;
 
@@ -28071,55 +27783,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__6"
+    // $ANTLR end "rule__Test__Group__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:9156:1: rule__BusinessRuleTaskFlowElement__Group__6__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_6__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:9162:1: rule__Test__Group__0__Impl : ( 'Test' ) ;
+    public final void rule__Test__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9160:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:9161:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:9166:1: ( ( 'Test' ) )
+            // InternalTestgeneratorDSL.g:9167:1: ( 'Test' )
             {
-            // InternalTestgeneratorDSL.g:9161:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:9162:2: ( rule__BusinessRuleTaskFlowElement__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:9167:1: ( 'Test' )
+            // InternalTestgeneratorDSL.g:9168:2: 'Test'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:9163:2: ( rule__BusinessRuleTaskFlowElement__Group_6__0 )?
-            int alt72=2;
-            int LA72_0 = input.LA(1);
-
-            if ( (LA72_0==28) ) {
-                int LA72_1 = input.LA(2);
+             before(grammarAccess.getTestAccess().getTestKeyword_0()); 
+            match(input,72,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getTestKeyword_0()); 
 
-                if ( (LA72_1==41) ) {
-                    alt72=1;
-                }
             }
-            switch (alt72) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9163:3: rule__BusinessRuleTaskFlowElement__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_6__0();
 
-                    state._fsp--;
 
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6()); 
-
-            }
-
-
-            }
+            }
 
         }
         catch (RecognitionException re) {
@@ -28133,26 +27820,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__6__Impl"
+    // $ANTLR end "rule__Test__Group__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__7"
-    // InternalTestgeneratorDSL.g:9171:1: rule__BusinessRuleTaskFlowElement__Group__7 : rule__BusinessRuleTaskFlowElement__Group__7__Impl rule__BusinessRuleTaskFlowElement__Group__8 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__1"
+    // InternalTestgeneratorDSL.g:9177:1: rule__Test__Group__1 : rule__Test__Group__1__Impl rule__Test__Group__2 ;
+    public final void rule__Test__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9175:1: ( rule__BusinessRuleTaskFlowElement__Group__7__Impl rule__BusinessRuleTaskFlowElement__Group__8 )
-            // InternalTestgeneratorDSL.g:9176:2: rule__BusinessRuleTaskFlowElement__Group__7__Impl rule__BusinessRuleTaskFlowElement__Group__8
+            // InternalTestgeneratorDSL.g:9181:1: ( rule__Test__Group__1__Impl rule__Test__Group__2 )
+            // InternalTestgeneratorDSL.g:9182:2: rule__Test__Group__1__Impl rule__Test__Group__2
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__7__Impl();
+            pushFollow(FOLLOW_52);
+            rule__Test__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__8();
+            rule__Test__Group__2();
 
             state._fsp--;
 
@@ -28171,46 +27858,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__7"
+    // $ANTLR end "rule__Test__Group__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:9183:1: rule__BusinessRuleTaskFlowElement__Group__7__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_7__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:9189:1: rule__Test__Group__1__Impl : ( ( rule__Test__NameAssignment_1 ) ) ;
+    public final void rule__Test__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9187:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:9188:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:9193:1: ( ( ( rule__Test__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:9194:1: ( ( rule__Test__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:9188:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:9189:2: ( rule__BusinessRuleTaskFlowElement__Group_7__0 )?
+            // InternalTestgeneratorDSL.g:9194:1: ( ( rule__Test__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:9195:2: ( rule__Test__NameAssignment_1 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:9190:2: ( rule__BusinessRuleTaskFlowElement__Group_7__0 )?
-            int alt73=2;
-            int LA73_0 = input.LA(1);
-
-            if ( (LA73_0==28) ) {
-                alt73=1;
-            }
-            switch (alt73) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9190:3: rule__BusinessRuleTaskFlowElement__Group_7__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_7__0();
-
-                    state._fsp--;
+             before(grammarAccess.getTestAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:9196:2: ( rule__Test__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:9196:3: rule__Test__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__NameAssignment_1();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7()); 
+             after(grammarAccess.getTestAccess().getNameAssignment_1()); 
 
             }
 
@@ -28229,26 +27905,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__7__Impl"
+    // $ANTLR end "rule__Test__Group__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__8"
-    // InternalTestgeneratorDSL.g:9198:1: rule__BusinessRuleTaskFlowElement__Group__8 : rule__BusinessRuleTaskFlowElement__Group__8__Impl rule__BusinessRuleTaskFlowElement__Group__9 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__2"
+    // InternalTestgeneratorDSL.g:9204:1: rule__Test__Group__2 : rule__Test__Group__2__Impl rule__Test__Group__3 ;
+    public final void rule__Test__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9202:1: ( rule__BusinessRuleTaskFlowElement__Group__8__Impl rule__BusinessRuleTaskFlowElement__Group__9 )
-            // InternalTestgeneratorDSL.g:9203:2: rule__BusinessRuleTaskFlowElement__Group__8__Impl rule__BusinessRuleTaskFlowElement__Group__9
+            // InternalTestgeneratorDSL.g:9208:1: ( rule__Test__Group__2__Impl rule__Test__Group__3 )
+            // InternalTestgeneratorDSL.g:9209:2: rule__Test__Group__2__Impl rule__Test__Group__3
             {
-            pushFollow(FOLLOW_26);
-            rule__BusinessRuleTaskFlowElement__Group__8__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Test__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__9();
+            rule__Test__Group__3();
 
             state._fsp--;
 
@@ -28267,46 +27943,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__8"
+    // $ANTLR end "rule__Test__Group__2"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:9210:1: rule__BusinessRuleTaskFlowElement__Group__8__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_8__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:9216:1: rule__Test__Group__2__Impl : ( 'for' ) ;
+    public final void rule__Test__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9214:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_8__0 )? ) )
-            // InternalTestgeneratorDSL.g:9215:1: ( ( rule__BusinessRuleTaskFlowElement__Group_8__0 )? )
+            // InternalTestgeneratorDSL.g:9220:1: ( ( 'for' ) )
+            // InternalTestgeneratorDSL.g:9221:1: ( 'for' )
             {
-            // InternalTestgeneratorDSL.g:9215:1: ( ( rule__BusinessRuleTaskFlowElement__Group_8__0 )? )
-            // InternalTestgeneratorDSL.g:9216:2: ( rule__BusinessRuleTaskFlowElement__Group_8__0 )?
+            // InternalTestgeneratorDSL.g:9221:1: ( 'for' )
+            // InternalTestgeneratorDSL.g:9222:2: 'for'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_8()); 
-            // InternalTestgeneratorDSL.g:9217:2: ( rule__BusinessRuleTaskFlowElement__Group_8__0 )?
-            int alt74=2;
-            int LA74_0 = input.LA(1);
-
-            if ( (LA74_0==43) ) {
-                alt74=1;
-            }
-            switch (alt74) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9217:3: rule__BusinessRuleTaskFlowElement__Group_8__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_8__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_8()); 
+             before(grammarAccess.getTestAccess().getForKeyword_2()); 
+            match(input,68,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getForKeyword_2()); 
 
             }
 
@@ -28325,21 +27980,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__8__Impl"
+    // $ANTLR end "rule__Test__Group__2__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__9"
-    // InternalTestgeneratorDSL.g:9225:1: rule__BusinessRuleTaskFlowElement__Group__9 : rule__BusinessRuleTaskFlowElement__Group__9__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__9() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__3"
+    // InternalTestgeneratorDSL.g:9231:1: rule__Test__Group__3 : rule__Test__Group__3__Impl rule__Test__Group__4 ;
+    public final void rule__Test__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9229:1: ( rule__BusinessRuleTaskFlowElement__Group__9__Impl )
-            // InternalTestgeneratorDSL.g:9230:2: rule__BusinessRuleTaskFlowElement__Group__9__Impl
+            // InternalTestgeneratorDSL.g:9235:1: ( rule__Test__Group__3__Impl rule__Test__Group__4 )
+            // InternalTestgeneratorDSL.g:9236:2: rule__Test__Group__3__Impl rule__Test__Group__4
             {
+            pushFollow(FOLLOW_10);
+            rule__Test__Group__3__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group__9__Impl();
+            rule__Test__Group__4();
 
             state._fsp--;
 
@@ -28358,25 +28018,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__9"
+    // $ANTLR end "rule__Test__Group__3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:9236:1: rule__BusinessRuleTaskFlowElement__Group__9__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group__9__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:9243:1: rule__Test__Group__3__Impl : ( ( rule__Test__FlowReferenceAssignment_3 ) ) ;
+    public final void rule__Test__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9240:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:9241:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:9247:1: ( ( ( rule__Test__FlowReferenceAssignment_3 ) ) )
+            // InternalTestgeneratorDSL.g:9248:1: ( ( rule__Test__FlowReferenceAssignment_3 ) )
             {
-            // InternalTestgeneratorDSL.g:9241:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:9242:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:9248:1: ( ( rule__Test__FlowReferenceAssignment_3 ) )
+            // InternalTestgeneratorDSL.g:9249:2: ( rule__Test__FlowReferenceAssignment_3 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9()); 
+             before(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); 
+            // InternalTestgeneratorDSL.g:9250:2: ( rule__Test__FlowReferenceAssignment_3 )
+            // InternalTestgeneratorDSL.g:9250:3: rule__Test__FlowReferenceAssignment_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__FlowReferenceAssignment_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); 
 
             }
 
@@ -28395,26 +28065,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group__9__Impl"
+    // $ANTLR end "rule__Test__Group__3__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:9252:1: rule__BusinessRuleTaskFlowElement__Group_4__0 : rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__4"
+    // InternalTestgeneratorDSL.g:9258:1: rule__Test__Group__4 : rule__Test__Group__4__Impl rule__Test__Group__5 ;
+    public final void rule__Test__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9256:1: ( rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:9257:2: rule__BusinessRuleTaskFlowElement__Group_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_4__1
+            // InternalTestgeneratorDSL.g:9262:1: ( rule__Test__Group__4__Impl rule__Test__Group__5 )
+            // InternalTestgeneratorDSL.g:9263:2: rule__Test__Group__4__Impl rule__Test__Group__5
             {
-            pushFollow(FOLLOW_37);
-            rule__BusinessRuleTaskFlowElement__Group_4__0__Impl();
+            pushFollow(FOLLOW_10);
+            rule__Test__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_4__1();
+            rule__Test__Group__5();
 
             state._fsp--;
 
@@ -28433,25 +28103,50 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__0"
+    // $ANTLR end "rule__Test__Group__4"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:9264:1: rule__BusinessRuleTaskFlowElement__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:9270:1: rule__Test__Group__4__Impl : ( ( rule__Test__Group_4__0 )? ) ;
+    public final void rule__Test__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9268:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:9269:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9274:1: ( ( ( rule__Test__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:9275:1: ( ( rule__Test__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:9269:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:9270:2: 'with'
+            // InternalTestgeneratorDSL.g:9275:1: ( ( rule__Test__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:9276:2: ( rule__Test__Group_4__0 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0()); 
+             before(grammarAccess.getTestAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:9277:2: ( rule__Test__Group_4__0 )?
+            int alt55=2;
+            int LA55_0 = input.LA(1);
+
+            if ( (LA55_0==29) ) {
+                int LA55_1 = input.LA(2);
+
+                if ( (LA55_1==73) ) {
+                    alt55=1;
+                }
+            }
+            switch (alt55) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9277:3: rule__Test__Group_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Test__Group_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getTestAccess().getGroup_4()); 
 
             }
 
@@ -28470,26 +28165,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__0__Impl"
+    // $ANTLR end "rule__Test__Group__4__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:9279:1: rule__BusinessRuleTaskFlowElement__Group_4__1 : rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__5"
+    // InternalTestgeneratorDSL.g:9285:1: rule__Test__Group__5 : rule__Test__Group__5__Impl rule__Test__Group__6 ;
+    public final void rule__Test__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9283:1: ( rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:9284:2: rule__BusinessRuleTaskFlowElement__Group_4__1__Impl rule__BusinessRuleTaskFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:9289:1: ( rule__Test__Group__5__Impl rule__Test__Group__6 )
+            // InternalTestgeneratorDSL.g:9290:2: rule__Test__Group__5__Impl rule__Test__Group__6
             {
-            pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group_4__1__Impl();
+            pushFollow(FOLLOW_10);
+            rule__Test__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_4__2();
+            rule__Test__Group__6();
 
             state._fsp--;
 
@@ -28508,25 +28203,50 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__1"
+    // $ANTLR end "rule__Test__Group__5"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:9291:1: rule__BusinessRuleTaskFlowElement__Group_4__1__Impl : ( 'resultVariable' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:9297:1: rule__Test__Group__5__Impl : ( ( rule__Test__Group_5__0 )? ) ;
+    public final void rule__Test__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9295:1: ( ( 'resultVariable' ) )
-            // InternalTestgeneratorDSL.g:9296:1: ( 'resultVariable' )
+            // InternalTestgeneratorDSL.g:9301:1: ( ( ( rule__Test__Group_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:9302:1: ( ( rule__Test__Group_5__0 )? )
             {
-            // InternalTestgeneratorDSL.g:9296:1: ( 'resultVariable' )
-            // InternalTestgeneratorDSL.g:9297:2: 'resultVariable'
+            // InternalTestgeneratorDSL.g:9302:1: ( ( rule__Test__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:9303:2: ( rule__Test__Group_5__0 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); 
-            match(input,51,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1()); 
+             before(grammarAccess.getTestAccess().getGroup_5()); 
+            // InternalTestgeneratorDSL.g:9304:2: ( rule__Test__Group_5__0 )?
+            int alt56=2;
+            int LA56_0 = input.LA(1);
+
+            if ( (LA56_0==29) ) {
+                int LA56_1 = input.LA(2);
+
+                if ( (LA56_1==75) ) {
+                    alt56=1;
+                }
+            }
+            switch (alt56) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9304:3: rule__Test__Group_5__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Test__Group_5__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getTestAccess().getGroup_5()); 
 
             }
 
@@ -28545,26 +28265,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__1__Impl"
+    // $ANTLR end "rule__Test__Group__5__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:9306:1: rule__BusinessRuleTaskFlowElement__Group_4__2 : rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__2() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__6"
+    // InternalTestgeneratorDSL.g:9312:1: rule__Test__Group__6 : rule__Test__Group__6__Impl rule__Test__Group__7 ;
+    public final void rule__Test__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9310:1: ( rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:9311:2: rule__BusinessRuleTaskFlowElement__Group_4__2__Impl rule__BusinessRuleTaskFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:9316:1: ( rule__Test__Group__6__Impl rule__Test__Group__7 )
+            // InternalTestgeneratorDSL.g:9317:2: rule__Test__Group__6__Impl rule__Test__Group__7
             {
-            pushFollow(FOLLOW_7);
-            rule__BusinessRuleTaskFlowElement__Group_4__2__Impl();
+            pushFollow(FOLLOW_10);
+            rule__Test__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_4__3();
+            rule__Test__Group__7();
 
             state._fsp--;
 
@@ -28583,25 +28303,50 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__2"
+    // $ANTLR end "rule__Test__Group__6"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:9318:1: rule__BusinessRuleTaskFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:9324:1: rule__Test__Group__6__Impl : ( ( rule__Test__EndCheckAssignment_6 )? ) ;
+    public final void rule__Test__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9322:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:9323:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9328:1: ( ( ( rule__Test__EndCheckAssignment_6 )? ) )
+            // InternalTestgeneratorDSL.g:9329:1: ( ( rule__Test__EndCheckAssignment_6 )? )
             {
-            // InternalTestgeneratorDSL.g:9323:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:9324:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:9329:1: ( ( rule__Test__EndCheckAssignment_6 )? )
+            // InternalTestgeneratorDSL.g:9330:2: ( rule__Test__EndCheckAssignment_6 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+             before(grammarAccess.getTestAccess().getEndCheckAssignment_6()); 
+            // InternalTestgeneratorDSL.g:9331:2: ( rule__Test__EndCheckAssignment_6 )?
+            int alt57=2;
+            int LA57_0 = input.LA(1);
+
+            if ( (LA57_0==29) ) {
+                int LA57_1 = input.LA(2);
+
+                if ( (LA57_1==76) ) {
+                    alt57=1;
+                }
+            }
+            switch (alt57) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9331:3: rule__Test__EndCheckAssignment_6
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Test__EndCheckAssignment_6();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getTestAccess().getEndCheckAssignment_6()); 
 
             }
 
@@ -28620,21 +28365,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__2__Impl"
+    // $ANTLR end "rule__Test__Group__6__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:9333:1: rule__BusinessRuleTaskFlowElement__Group_4__3 : rule__BusinessRuleTaskFlowElement__Group_4__3__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__3() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__7"
+    // InternalTestgeneratorDSL.g:9339:1: rule__Test__Group__7 : rule__Test__Group__7__Impl rule__Test__Group__8 ;
+    public final void rule__Test__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9337:1: ( rule__BusinessRuleTaskFlowElement__Group_4__3__Impl )
-            // InternalTestgeneratorDSL.g:9338:2: rule__BusinessRuleTaskFlowElement__Group_4__3__Impl
+            // InternalTestgeneratorDSL.g:9343:1: ( rule__Test__Group__7__Impl rule__Test__Group__8 )
+            // InternalTestgeneratorDSL.g:9344:2: rule__Test__Group__7__Impl rule__Test__Group__8
             {
+            pushFollow(FOLLOW_10);
+            rule__Test__Group__7__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_4__3__Impl();
+            rule__Test__Group__8();
 
             state._fsp--;
 
@@ -28653,35 +28403,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__3"
+    // $ANTLR end "rule__Test__Group__7"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:9344:1: rule__BusinessRuleTaskFlowElement__Group_4__3__Impl : ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_4__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:9351:1: rule__Test__Group__7__Impl : ( ( rule__Test__Group_7__0 )? ) ;
+    public final void rule__Test__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9348:1: ( ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) ) )
-            // InternalTestgeneratorDSL.g:9349:1: ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:9349:1: ( ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 ) )
-            // InternalTestgeneratorDSL.g:9350:2: ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:9355:1: ( ( ( rule__Test__Group_7__0 )? ) )
+            // InternalTestgeneratorDSL.g:9356:1: ( ( rule__Test__Group_7__0 )? )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); 
-            // InternalTestgeneratorDSL.g:9351:2: ( rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 )
-            // InternalTestgeneratorDSL.g:9351:3: rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3
+            // InternalTestgeneratorDSL.g:9356:1: ( ( rule__Test__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:9357:2: ( rule__Test__Group_7__0 )?
             {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3();
+             before(grammarAccess.getTestAccess().getGroup_7()); 
+            // InternalTestgeneratorDSL.g:9358:2: ( rule__Test__Group_7__0 )?
+            int alt58=2;
+            int LA58_0 = input.LA(1);
 
-            state._fsp--;
+            if ( (LA58_0==29) ) {
+                alt58=1;
+            }
+            switch (alt58) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9358:3: rule__Test__Group_7__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Test__Group_7__0();
+
+                    state._fsp--;
 
 
+                    }
+                    break;
+
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableAssignment_4_3()); 
+             after(grammarAccess.getTestAccess().getGroup_7()); 
 
             }
 
@@ -28700,26 +28461,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_4__3__Impl"
+    // $ANTLR end "rule__Test__Group__7__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__0"
-    // InternalTestgeneratorDSL.g:9360:1: rule__BusinessRuleTaskFlowElement__Group_5__0 : rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__8"
+    // InternalTestgeneratorDSL.g:9366:1: rule__Test__Group__8 : rule__Test__Group__8__Impl ;
+    public final void rule__Test__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9364:1: ( rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1 )
-            // InternalTestgeneratorDSL.g:9365:2: rule__BusinessRuleTaskFlowElement__Group_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5__1
+            // InternalTestgeneratorDSL.g:9370:1: ( rule__Test__Group__8__Impl )
+            // InternalTestgeneratorDSL.g:9371:2: rule__Test__Group__8__Impl
             {
-            pushFollow(FOLLOW_19);
-            rule__BusinessRuleTaskFlowElement__Group_5__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__1();
+            rule__Test__Group__8__Impl();
 
             state._fsp--;
 
@@ -28738,25 +28494,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__0"
+    // $ANTLR end "rule__Test__Group__8"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:9372:1: rule__BusinessRuleTaskFlowElement__Group_5__0__Impl : ( 'with' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:9377:1: rule__Test__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__Test__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9376:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:9377:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9381:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:9382:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:9377:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:9378:2: 'with'
+            // InternalTestgeneratorDSL.g:9382:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:9383:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_5_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_5_0()); 
+             before(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
 
             }
 
@@ -28775,26 +28531,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__0__Impl"
+    // $ANTLR end "rule__Test__Group__8__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__1"
-    // InternalTestgeneratorDSL.g:9387:1: rule__BusinessRuleTaskFlowElement__Group_5__1 : rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__0"
+    // InternalTestgeneratorDSL.g:9393:1: rule__Test__Group_4__0 : rule__Test__Group_4__0__Impl rule__Test__Group_4__1 ;
+    public final void rule__Test__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9391:1: ( rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2 )
-            // InternalTestgeneratorDSL.g:9392:2: rule__BusinessRuleTaskFlowElement__Group_5__1__Impl rule__BusinessRuleTaskFlowElement__Group_5__2
+            // InternalTestgeneratorDSL.g:9397:1: ( rule__Test__Group_4__0__Impl rule__Test__Group_4__1 )
+            // InternalTestgeneratorDSL.g:9398:2: rule__Test__Group_4__0__Impl rule__Test__Group_4__1
             {
-            pushFollow(FOLLOW_20);
-            rule__BusinessRuleTaskFlowElement__Group_5__1__Impl();
+            pushFollow(FOLLOW_56);
+            rule__Test__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__2();
+            rule__Test__Group_4__1();
 
             state._fsp--;
 
@@ -28813,25 +28569,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__1"
+    // $ANTLR end "rule__Test__Group_4__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:9399:1: rule__BusinessRuleTaskFlowElement__Group_5__1__Impl : ( 'hardcoded' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:9405:1: rule__Test__Group_4__0__Impl : ( 'with' ) ;
+    public final void rule__Test__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9403:1: ( ( 'hardcoded' ) )
-            // InternalTestgeneratorDSL.g:9404:1: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:9409:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:9410:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:9404:1: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:9405:2: 'hardcoded'
+            // InternalTestgeneratorDSL.g:9410:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9411:2: 'with'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedKeyword_5_1()); 
-            match(input,36,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedKeyword_5_1()); 
+             before(grammarAccess.getTestAccess().getWithKeyword_4_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getWithKeyword_4_0()); 
 
             }
 
@@ -28850,26 +28606,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__1__Impl"
+    // $ANTLR end "rule__Test__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__2"
-    // InternalTestgeneratorDSL.g:9414:1: rule__BusinessRuleTaskFlowElement__Group_5__2 : rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__2() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__1"
+    // InternalTestgeneratorDSL.g:9420:1: rule__Test__Group_4__1 : rule__Test__Group_4__1__Impl rule__Test__Group_4__2 ;
+    public final void rule__Test__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9418:1: ( rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3 )
-            // InternalTestgeneratorDSL.g:9419:2: rule__BusinessRuleTaskFlowElement__Group_5__2__Impl rule__BusinessRuleTaskFlowElement__Group_5__3
+            // InternalTestgeneratorDSL.g:9424:1: ( rule__Test__Group_4__1__Impl rule__Test__Group_4__2 )
+            // InternalTestgeneratorDSL.g:9425:2: rule__Test__Group_4__1__Impl rule__Test__Group_4__2
             {
-            pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group_5__2__Impl();
+            pushFollow(FOLLOW_42);
+            rule__Test__Group_4__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__3();
+            rule__Test__Group_4__2();
 
             state._fsp--;
 
@@ -28888,25 +28644,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__2"
+    // $ANTLR end "rule__Test__Group_4__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__2__Impl"
-    // InternalTestgeneratorDSL.g:9426:1: rule__BusinessRuleTaskFlowElement__Group_5__2__Impl : ( 'inputs' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:9432:1: rule__Test__Group_4__1__Impl : ( 'priority' ) ;
+    public final void rule__Test__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9430:1: ( ( 'inputs' ) )
-            // InternalTestgeneratorDSL.g:9431:1: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:9436:1: ( ( 'priority' ) )
+            // InternalTestgeneratorDSL.g:9437:1: ( 'priority' )
             {
-            // InternalTestgeneratorDSL.g:9431:1: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:9432:2: 'inputs'
+            // InternalTestgeneratorDSL.g:9437:1: ( 'priority' )
+            // InternalTestgeneratorDSL.g:9438:2: 'priority'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputsKeyword_5_2()); 
-            match(input,37,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputsKeyword_5_2()); 
+             before(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); 
+            match(input,73,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); 
 
             }
 
@@ -28925,26 +28681,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__2__Impl"
+    // $ANTLR end "rule__Test__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__3"
-    // InternalTestgeneratorDSL.g:9441:1: rule__BusinessRuleTaskFlowElement__Group_5__3 : rule__BusinessRuleTaskFlowElement__Group_5__3__Impl rule__BusinessRuleTaskFlowElement__Group_5__4 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__3() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__2"
+    // InternalTestgeneratorDSL.g:9447:1: rule__Test__Group_4__2 : rule__Test__Group_4__2__Impl ;
+    public final void rule__Test__Group_4__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9445:1: ( rule__BusinessRuleTaskFlowElement__Group_5__3__Impl rule__BusinessRuleTaskFlowElement__Group_5__4 )
-            // InternalTestgeneratorDSL.g:9446:2: rule__BusinessRuleTaskFlowElement__Group_5__3__Impl rule__BusinessRuleTaskFlowElement__Group_5__4
+            // InternalTestgeneratorDSL.g:9451:1: ( rule__Test__Group_4__2__Impl )
+            // InternalTestgeneratorDSL.g:9452:2: rule__Test__Group_4__2__Impl
             {
-            pushFollow(FOLLOW_13);
-            rule__BusinessRuleTaskFlowElement__Group_5__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__4();
+            rule__Test__Group_4__2__Impl();
 
             state._fsp--;
 
@@ -28963,25 +28714,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__3"
+    // $ANTLR end "rule__Test__Group_4__2"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__3__Impl"
-    // InternalTestgeneratorDSL.g:9453:1: rule__BusinessRuleTaskFlowElement__Group_5__3__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_4__2__Impl"
+    // InternalTestgeneratorDSL.g:9458:1: rule__Test__Group_4__2__Impl : ( ( rule__Test__PriorityAssignment_4_2 ) ) ;
+    public final void rule__Test__Group_4__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9457:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:9458:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9462:1: ( ( ( rule__Test__PriorityAssignment_4_2 ) ) )
+            // InternalTestgeneratorDSL.g:9463:1: ( ( rule__Test__PriorityAssignment_4_2 ) )
             {
-            // InternalTestgeneratorDSL.g:9458:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:9459:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:9463:1: ( ( rule__Test__PriorityAssignment_4_2 ) )
+            // InternalTestgeneratorDSL.g:9464:2: ( rule__Test__PriorityAssignment_4_2 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_3()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_3()); 
+             before(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); 
+            // InternalTestgeneratorDSL.g:9465:2: ( rule__Test__PriorityAssignment_4_2 )
+            // InternalTestgeneratorDSL.g:9465:3: rule__Test__PriorityAssignment_4_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__PriorityAssignment_4_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); 
 
             }
 
@@ -29000,26 +28761,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__3__Impl"
+    // $ANTLR end "rule__Test__Group_4__2__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__4"
-    // InternalTestgeneratorDSL.g:9468:1: rule__BusinessRuleTaskFlowElement__Group_5__4 : rule__BusinessRuleTaskFlowElement__Group_5__4__Impl rule__BusinessRuleTaskFlowElement__Group_5__5 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__4() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5__0"
+    // InternalTestgeneratorDSL.g:9474:1: rule__Test__Group_5__0 : rule__Test__Group_5__0__Impl rule__Test__Group_5__1 ;
+    public final void rule__Test__Group_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9472:1: ( rule__BusinessRuleTaskFlowElement__Group_5__4__Impl rule__BusinessRuleTaskFlowElement__Group_5__5 )
-            // InternalTestgeneratorDSL.g:9473:2: rule__BusinessRuleTaskFlowElement__Group_5__4__Impl rule__BusinessRuleTaskFlowElement__Group_5__5
+            // InternalTestgeneratorDSL.g:9478:1: ( rule__Test__Group_5__0__Impl rule__Test__Group_5__1 )
+            // InternalTestgeneratorDSL.g:9479:2: rule__Test__Group_5__0__Impl rule__Test__Group_5__1
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_5__4__Impl();
+            pushFollow(FOLLOW_15);
+            rule__Test__Group_5__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__5();
+            rule__Test__Group_5__1();
 
             state._fsp--;
 
@@ -29038,25 +28799,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__4"
+    // $ANTLR end "rule__Test__Group_5__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__4__Impl"
-    // InternalTestgeneratorDSL.g:9480:1: rule__BusinessRuleTaskFlowElement__Group_5__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5__0__Impl"
+    // InternalTestgeneratorDSL.g:9486:1: rule__Test__Group_5__0__Impl : ( ( rule__Test__DeclarationsAssignment_5_0 ) ) ;
+    public final void rule__Test__Group_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9484:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:9485:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:9490:1: ( ( ( rule__Test__DeclarationsAssignment_5_0 ) ) )
+            // InternalTestgeneratorDSL.g:9491:1: ( ( rule__Test__DeclarationsAssignment_5_0 ) )
             {
-            // InternalTestgeneratorDSL.g:9485:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:9486:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:9491:1: ( ( rule__Test__DeclarationsAssignment_5_0 ) )
+            // InternalTestgeneratorDSL.g:9492:2: ( rule__Test__DeclarationsAssignment_5_0 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_4()); 
+             before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); 
+            // InternalTestgeneratorDSL.g:9493:2: ( rule__Test__DeclarationsAssignment_5_0 )
+            // InternalTestgeneratorDSL.g:9493:3: rule__Test__DeclarationsAssignment_5_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__DeclarationsAssignment_5_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); 
 
             }
 
@@ -29075,26 +28846,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__4__Impl"
+    // $ANTLR end "rule__Test__Group_5__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__5"
-    // InternalTestgeneratorDSL.g:9495:1: rule__BusinessRuleTaskFlowElement__Group_5__5 : rule__BusinessRuleTaskFlowElement__Group_5__5__Impl rule__BusinessRuleTaskFlowElement__Group_5__6 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__5() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5__1"
+    // InternalTestgeneratorDSL.g:9501:1: rule__Test__Group_5__1 : rule__Test__Group_5__1__Impl ;
+    public final void rule__Test__Group_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9499:1: ( rule__BusinessRuleTaskFlowElement__Group_5__5__Impl rule__BusinessRuleTaskFlowElement__Group_5__6 )
-            // InternalTestgeneratorDSL.g:9500:2: rule__BusinessRuleTaskFlowElement__Group_5__5__Impl rule__BusinessRuleTaskFlowElement__Group_5__6
+            // InternalTestgeneratorDSL.g:9505:1: ( rule__Test__Group_5__1__Impl )
+            // InternalTestgeneratorDSL.g:9506:2: rule__Test__Group_5__1__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_5__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__6();
+            rule__Test__Group_5__1__Impl();
 
             state._fsp--;
 
@@ -29113,46 +28879,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__5"
+    // $ANTLR end "rule__Test__Group_5__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__5__Impl"
-    // InternalTestgeneratorDSL.g:9507:1: rule__BusinessRuleTaskFlowElement__Group_5__5__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5__1__Impl"
+    // InternalTestgeneratorDSL.g:9512:1: rule__Test__Group_5__1__Impl : ( ( rule__Test__Group_5_1__0 )* ) ;
+    public final void rule__Test__Group_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9511:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:9512:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )? )
+            // InternalTestgeneratorDSL.g:9516:1: ( ( ( rule__Test__Group_5_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:9517:1: ( ( rule__Test__Group_5_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:9512:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )? )
-            // InternalTestgeneratorDSL.g:9513:2: ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )?
+            // InternalTestgeneratorDSL.g:9517:1: ( ( rule__Test__Group_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:9518:2: ( rule__Test__Group_5_1__0 )*
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5()); 
-            // InternalTestgeneratorDSL.g:9514:2: ( rule__BusinessRuleTaskFlowElement__Group_5_5__0 )?
-            int alt75=2;
-            int LA75_0 = input.LA(1);
+             before(grammarAccess.getTestAccess().getGroup_5_1()); 
+            // InternalTestgeneratorDSL.g:9519:2: ( rule__Test__Group_5_1__0 )*
+            loop59:
+            do {
+                int alt59=2;
+                int LA59_0 = input.LA(1);
 
-            if ( (LA75_0==RULE_ID) ) {
-                alt75=1;
-            }
-            switch (alt75) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9514:3: rule__BusinessRuleTaskFlowElement__Group_5_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_5_5__0();
+                if ( (LA59_0==RULE_SEPARATOR) ) {
+                    alt59=1;
+                }
 
-                    state._fsp--;
 
+                switch (alt59) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:9519:3: rule__Test__Group_5_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__Test__Group_5_1__0();
+
+            	    state._fsp--;
 
-                    }
-                    break;
 
-            }
+            	    }
+            	    break;
+
+            	default :
+            	    break loop59;
+                }
+            } while (true);
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5()); 
+             after(grammarAccess.getTestAccess().getGroup_5_1()); 
 
             }
 
@@ -29171,21 +28944,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__5__Impl"
+    // $ANTLR end "rule__Test__Group_5__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__6"
-    // InternalTestgeneratorDSL.g:9522:1: rule__BusinessRuleTaskFlowElement__Group_5__6 : rule__BusinessRuleTaskFlowElement__Group_5__6__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__6() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5_1__0"
+    // InternalTestgeneratorDSL.g:9528:1: rule__Test__Group_5_1__0 : rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1 ;
+    public final void rule__Test__Group_5_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9526:1: ( rule__BusinessRuleTaskFlowElement__Group_5__6__Impl )
-            // InternalTestgeneratorDSL.g:9527:2: rule__BusinessRuleTaskFlowElement__Group_5__6__Impl
+            // InternalTestgeneratorDSL.g:9532:1: ( rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1 )
+            // InternalTestgeneratorDSL.g:9533:2: rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1
             {
+            pushFollow(FOLLOW_5);
+            rule__Test__Group_5_1__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5__6__Impl();
+            rule__Test__Group_5_1__1();
 
             state._fsp--;
 
@@ -29204,25 +28982,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__6"
+    // $ANTLR end "rule__Test__Group_5_1__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5__6__Impl"
-    // InternalTestgeneratorDSL.g:9533:1: rule__BusinessRuleTaskFlowElement__Group_5__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5_1__0__Impl"
+    // InternalTestgeneratorDSL.g:9540:1: rule__Test__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__Test__Group_5_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9537:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:9538:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:9544:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:9545:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:9538:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:9539:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:9545:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:9546:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_6()); 
+             before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
 
             }
 
@@ -29241,26 +29019,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5__6__Impl"
+    // $ANTLR end "rule__Test__Group_5_1__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5__0"
-    // InternalTestgeneratorDSL.g:9549:1: rule__BusinessRuleTaskFlowElement__Group_5_5__0 : rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5_1__1"
+    // InternalTestgeneratorDSL.g:9555:1: rule__Test__Group_5_1__1 : rule__Test__Group_5_1__1__Impl ;
+    public final void rule__Test__Group_5_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9553:1: ( rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5__1 )
-            // InternalTestgeneratorDSL.g:9554:2: rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5__1
+            // InternalTestgeneratorDSL.g:9559:1: ( rule__Test__Group_5_1__1__Impl )
+            // InternalTestgeneratorDSL.g:9560:2: rule__Test__Group_5_1__1__Impl
             {
-            pushFollow(FOLLOW_15);
-            rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5_5__1();
+            rule__Test__Group_5_1__1__Impl();
 
             state._fsp--;
 
@@ -29279,35 +29052,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5__0"
+    // $ANTLR end "rule__Test__Group_5_1__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl"
-    // InternalTestgeneratorDSL.g:9561:1: rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl : ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_5_1__1__Impl"
+    // InternalTestgeneratorDSL.g:9566:1: rule__Test__Group_5_1__1__Impl : ( ( rule__Test__DeclarationsAssignment_5_1_1 ) ) ;
+    public final void rule__Test__Group_5_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9565:1: ( ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:9566:1: ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 ) )
+            // InternalTestgeneratorDSL.g:9570:1: ( ( ( rule__Test__DeclarationsAssignment_5_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:9571:1: ( ( rule__Test__DeclarationsAssignment_5_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:9566:1: ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 ) )
-            // InternalTestgeneratorDSL.g:9567:2: ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 )
+            // InternalTestgeneratorDSL.g:9571:1: ( ( rule__Test__DeclarationsAssignment_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:9572:2: ( rule__Test__DeclarationsAssignment_5_1_1 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_0()); 
-            // InternalTestgeneratorDSL.g:9568:2: ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 )
-            // InternalTestgeneratorDSL.g:9568:3: rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0
+             before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); 
+            // InternalTestgeneratorDSL.g:9573:2: ( rule__Test__DeclarationsAssignment_5_1_1 )
+            // InternalTestgeneratorDSL.g:9573:3: rule__Test__DeclarationsAssignment_5_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0();
+            rule__Test__DeclarationsAssignment_5_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_0()); 
+             after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); 
 
             }
 
@@ -29326,21 +29099,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5__0__Impl"
+    // $ANTLR end "rule__Test__Group_5_1__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5__1"
-    // InternalTestgeneratorDSL.g:9576:1: rule__BusinessRuleTaskFlowElement__Group_5_5__1 : rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__0"
+    // InternalTestgeneratorDSL.g:9582:1: rule__Test__Group_7__0 : rule__Test__Group_7__0__Impl rule__Test__Group_7__1 ;
+    public final void rule__Test__Group_7__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9580:1: ( rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl )
-            // InternalTestgeneratorDSL.g:9581:2: rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl
+            // InternalTestgeneratorDSL.g:9586:1: ( rule__Test__Group_7__0__Impl rule__Test__Group_7__1 )
+            // InternalTestgeneratorDSL.g:9587:2: rule__Test__Group_7__0__Impl rule__Test__Group_7__1
             {
+            pushFollow(FOLLOW_57);
+            rule__Test__Group_7__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl();
+            rule__Test__Group_7__1();
 
             state._fsp--;
 
@@ -29359,53 +29137,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5__1"
+    // $ANTLR end "rule__Test__Group_7__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl"
-    // InternalTestgeneratorDSL.g:9587:1: rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )* ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__0__Impl"
+    // InternalTestgeneratorDSL.g:9594:1: rule__Test__Group_7__0__Impl : ( 'with' ) ;
+    public final void rule__Test__Group_7__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9591:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:9592:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:9598:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:9599:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:9592:1: ( ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:9593:2: ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )*
+            // InternalTestgeneratorDSL.g:9599:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9600:2: 'with'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5_1()); 
-            // InternalTestgeneratorDSL.g:9594:2: ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 )*
-            loop76:
-            do {
-                int alt76=2;
-                int LA76_0 = input.LA(1);
-
-                if ( (LA76_0==RULE_SEPARATOR) ) {
-                    alt76=1;
-                }
-
-
-                switch (alt76) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:9594:3: rule__BusinessRuleTaskFlowElement__Group_5_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__BusinessRuleTaskFlowElement__Group_5_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop76;
-                }
-            } while (true);
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_5_5_1()); 
+             before(grammarAccess.getTestAccess().getWithKeyword_7_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getWithKeyword_7_0()); 
 
             }
 
@@ -29424,26 +29174,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5__1__Impl"
+    // $ANTLR end "rule__Test__Group_7__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5_1__0"
-    // InternalTestgeneratorDSL.g:9603:1: rule__BusinessRuleTaskFlowElement__Group_5_5_1__0 : rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5_1__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__1"
+    // InternalTestgeneratorDSL.g:9609:1: rule__Test__Group_7__1 : rule__Test__Group_7__1__Impl rule__Test__Group_7__2 ;
+    public final void rule__Test__Group_7__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9607:1: ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5_1__1 )
-            // InternalTestgeneratorDSL.g:9608:2: rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_5_5_1__1
+            // InternalTestgeneratorDSL.g:9613:1: ( rule__Test__Group_7__1__Impl rule__Test__Group_7__2 )
+            // InternalTestgeneratorDSL.g:9614:2: rule__Test__Group_7__1__Impl rule__Test__Group_7__2
             {
-            pushFollow(FOLLOW_4);
-            rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl();
+            pushFollow(FOLLOW_12);
+            rule__Test__Group_7__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5_5_1__1();
+            rule__Test__Group_7__2();
 
             state._fsp--;
 
@@ -29462,25 +29212,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5_1__0"
+    // $ANTLR end "rule__Test__Group_7__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:9615:1: rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__1__Impl"
+    // InternalTestgeneratorDSL.g:9621:1: rule__Test__Group_7__1__Impl : ( 'mocks' ) ;
+    public final void rule__Test__Group_7__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9619:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:9620:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:9625:1: ( ( 'mocks' ) )
+            // InternalTestgeneratorDSL.g:9626:1: ( 'mocks' )
             {
-            // InternalTestgeneratorDSL.g:9620:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:9621:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:9626:1: ( 'mocks' )
+            // InternalTestgeneratorDSL.g:9627:2: 'mocks'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_5_1_0()); 
+             before(grammarAccess.getTestAccess().getMocksKeyword_7_1()); 
+            match(input,74,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getMocksKeyword_7_1()); 
 
             }
 
@@ -29499,21 +29249,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5_1__0__Impl"
+    // $ANTLR end "rule__Test__Group_7__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5_1__1"
-    // InternalTestgeneratorDSL.g:9630:1: rule__BusinessRuleTaskFlowElement__Group_5_5_1__1 : rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5_1__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__2"
+    // InternalTestgeneratorDSL.g:9636:1: rule__Test__Group_7__2 : rule__Test__Group_7__2__Impl rule__Test__Group_7__3 ;
+    public final void rule__Test__Group_7__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9634:1: ( rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:9635:2: rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl
+            // InternalTestgeneratorDSL.g:9640:1: ( rule__Test__Group_7__2__Impl rule__Test__Group_7__3 )
+            // InternalTestgeneratorDSL.g:9641:2: rule__Test__Group_7__2__Impl rule__Test__Group_7__3
             {
+            pushFollow(FOLLOW_13);
+            rule__Test__Group_7__2__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl();
+            rule__Test__Group_7__3();
 
             state._fsp--;
 
@@ -29532,35 +29287,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5_1__1"
+    // $ANTLR end "rule__Test__Group_7__2"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:9641:1: rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__2__Impl"
+    // InternalTestgeneratorDSL.g:9648:1: rule__Test__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__Test__Group_7__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9645:1: ( ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:9646:1: ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:9652:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:9653:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:9646:1: ( ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:9647:2: ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 )
+            // InternalTestgeneratorDSL.g:9653:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9654:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_1_1()); 
-            // InternalTestgeneratorDSL.g:9648:2: ( rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 )
-            // InternalTestgeneratorDSL.g:9648:3: rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsAssignment_5_5_1_1()); 
+             before(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
 
             }
 
@@ -29579,26 +29324,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_5_5_1__1__Impl"
+    // $ANTLR end "rule__Test__Group_7__2__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__0"
-    // InternalTestgeneratorDSL.g:9657:1: rule__BusinessRuleTaskFlowElement__Group_6__0 : rule__BusinessRuleTaskFlowElement__Group_6__0__Impl rule__BusinessRuleTaskFlowElement__Group_6__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__3"
+    // InternalTestgeneratorDSL.g:9663:1: rule__Test__Group_7__3 : rule__Test__Group_7__3__Impl rule__Test__Group_7__4 ;
+    public final void rule__Test__Group_7__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9661:1: ( rule__BusinessRuleTaskFlowElement__Group_6__0__Impl rule__BusinessRuleTaskFlowElement__Group_6__1 )
-            // InternalTestgeneratorDSL.g:9662:2: rule__BusinessRuleTaskFlowElement__Group_6__0__Impl rule__BusinessRuleTaskFlowElement__Group_6__1
+            // InternalTestgeneratorDSL.g:9667:1: ( rule__Test__Group_7__3__Impl rule__Test__Group_7__4 )
+            // InternalTestgeneratorDSL.g:9668:2: rule__Test__Group_7__3__Impl rule__Test__Group_7__4
             {
-            pushFollow(FOLLOW_27);
-            rule__BusinessRuleTaskFlowElement__Group_6__0__Impl();
+            pushFollow(FOLLOW_20);
+            rule__Test__Group_7__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__1();
+            rule__Test__Group_7__4();
 
             state._fsp--;
 
@@ -29617,25 +29362,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__0"
+    // $ANTLR end "rule__Test__Group_7__3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:9669:1: rule__BusinessRuleTaskFlowElement__Group_6__0__Impl : ( 'with' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__3__Impl"
+    // InternalTestgeneratorDSL.g:9675:1: rule__Test__Group_7__3__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__Test__Group_7__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9673:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:9674:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9679:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:9680:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:9674:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:9675:2: 'with'
+            // InternalTestgeneratorDSL.g:9680:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:9681:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_6_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_6_0()); 
+             before(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); 
 
             }
 
@@ -29654,26 +29399,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__0__Impl"
+    // $ANTLR end "rule__Test__Group_7__3__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__1"
-    // InternalTestgeneratorDSL.g:9684:1: rule__BusinessRuleTaskFlowElement__Group_6__1 : rule__BusinessRuleTaskFlowElement__Group_6__1__Impl rule__BusinessRuleTaskFlowElement__Group_6__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__4"
+    // InternalTestgeneratorDSL.g:9690:1: rule__Test__Group_7__4 : rule__Test__Group_7__4__Impl rule__Test__Group_7__5 ;
+    public final void rule__Test__Group_7__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9688:1: ( rule__BusinessRuleTaskFlowElement__Group_6__1__Impl rule__BusinessRuleTaskFlowElement__Group_6__2 )
-            // InternalTestgeneratorDSL.g:9689:2: rule__BusinessRuleTaskFlowElement__Group_6__1__Impl rule__BusinessRuleTaskFlowElement__Group_6__2
+            // InternalTestgeneratorDSL.g:9694:1: ( rule__Test__Group_7__4__Impl rule__Test__Group_7__5 )
+            // InternalTestgeneratorDSL.g:9695:2: rule__Test__Group_7__4__Impl rule__Test__Group_7__5
             {
-            pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group_6__1__Impl();
+            pushFollow(FOLLOW_20);
+            rule__Test__Group_7__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__2();
+            rule__Test__Group_7__5();
 
             state._fsp--;
 
@@ -29692,100 +29437,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__1"
+    // $ANTLR end "rule__Test__Group_7__4"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:9696:1: rule__BusinessRuleTaskFlowElement__Group_6__1__Impl : ( 'inputVariables' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__4__Impl"
+    // InternalTestgeneratorDSL.g:9702:1: rule__Test__Group_7__4__Impl : ( ( rule__Test__Group_7_4__0 )? ) ;
+    public final void rule__Test__Group_7__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9700:1: ( ( 'inputVariables' ) )
-            // InternalTestgeneratorDSL.g:9701:1: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:9706:1: ( ( ( rule__Test__Group_7_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:9707:1: ( ( rule__Test__Group_7_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:9701:1: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:9702:2: 'inputVariables'
+            // InternalTestgeneratorDSL.g:9707:1: ( ( rule__Test__Group_7_4__0 )? )
+            // InternalTestgeneratorDSL.g:9708:2: ( rule__Test__Group_7_4__0 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesKeyword_6_1()); 
-            match(input,41,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesKeyword_6_1()); 
-
-            }
-
+             before(grammarAccess.getTestAccess().getGroup_7_4()); 
+            // InternalTestgeneratorDSL.g:9709:2: ( rule__Test__Group_7_4__0 )?
+            int alt60=2;
+            int LA60_0 = input.LA(1);
 
+            if ( (LA60_0==RULE_ID) ) {
+                alt60=1;
             }
+            switch (alt60) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:9709:3: rule__Test__Group_7_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__Test__Group_7_4__0();
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__1__Impl"
-
-
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__2"
-    // InternalTestgeneratorDSL.g:9711:1: rule__BusinessRuleTaskFlowElement__Group_6__2 : rule__BusinessRuleTaskFlowElement__Group_6__2__Impl rule__BusinessRuleTaskFlowElement__Group_6__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:9715:1: ( rule__BusinessRuleTaskFlowElement__Group_6__2__Impl rule__BusinessRuleTaskFlowElement__Group_6__3 )
-            // InternalTestgeneratorDSL.g:9716:2: rule__BusinessRuleTaskFlowElement__Group_6__2__Impl rule__BusinessRuleTaskFlowElement__Group_6__3
-            {
-            pushFollow(FOLLOW_13);
-            rule__BusinessRuleTaskFlowElement__Group_6__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__3();
+                    state._fsp--;
 
-            state._fsp--;
 
+                    }
+                    break;
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__2"
-
-
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__2__Impl"
-    // InternalTestgeneratorDSL.g:9723:1: rule__BusinessRuleTaskFlowElement__Group_6__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:9727:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:9728:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:9728:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:9729:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2()); 
+             after(grammarAccess.getTestAccess().getGroup_7_4()); 
 
             }
 
@@ -29804,26 +29495,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__2__Impl"
+    // $ANTLR end "rule__Test__Group_7__4__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__3"
-    // InternalTestgeneratorDSL.g:9738:1: rule__BusinessRuleTaskFlowElement__Group_6__3 : rule__BusinessRuleTaskFlowElement__Group_6__3__Impl rule__BusinessRuleTaskFlowElement__Group_6__4 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__3() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__5"
+    // InternalTestgeneratorDSL.g:9717:1: rule__Test__Group_7__5 : rule__Test__Group_7__5__Impl ;
+    public final void rule__Test__Group_7__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9742:1: ( rule__BusinessRuleTaskFlowElement__Group_6__3__Impl rule__BusinessRuleTaskFlowElement__Group_6__4 )
-            // InternalTestgeneratorDSL.g:9743:2: rule__BusinessRuleTaskFlowElement__Group_6__3__Impl rule__BusinessRuleTaskFlowElement__Group_6__4
+            // InternalTestgeneratorDSL.g:9721:1: ( rule__Test__Group_7__5__Impl )
+            // InternalTestgeneratorDSL.g:9722:2: rule__Test__Group_7__5__Impl
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_6__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__4();
+            rule__Test__Group_7__5__Impl();
 
             state._fsp--;
 
@@ -29842,25 +29528,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__3"
+    // $ANTLR end "rule__Test__Group_7__5"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__3__Impl"
-    // InternalTestgeneratorDSL.g:9750:1: rule__BusinessRuleTaskFlowElement__Group_6__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7__5__Impl"
+    // InternalTestgeneratorDSL.g:9728:1: rule__Test__Group_7__5__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__Test__Group_7__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9754:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:9755:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:9732:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:9733:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:9755:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:9756:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:9733:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:9734:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3()); 
+             before(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
 
             }
 
@@ -29879,26 +29565,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__3__Impl"
+    // $ANTLR end "rule__Test__Group_7__5__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__4"
-    // InternalTestgeneratorDSL.g:9765:1: rule__BusinessRuleTaskFlowElement__Group_6__4 : rule__BusinessRuleTaskFlowElement__Group_6__4__Impl rule__BusinessRuleTaskFlowElement__Group_6__5 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__4() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4__0"
+    // InternalTestgeneratorDSL.g:9744:1: rule__Test__Group_7_4__0 : rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1 ;
+    public final void rule__Test__Group_7_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9769:1: ( rule__BusinessRuleTaskFlowElement__Group_6__4__Impl rule__BusinessRuleTaskFlowElement__Group_6__5 )
-            // InternalTestgeneratorDSL.g:9770:2: rule__BusinessRuleTaskFlowElement__Group_6__4__Impl rule__BusinessRuleTaskFlowElement__Group_6__5
+            // InternalTestgeneratorDSL.g:9748:1: ( rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1 )
+            // InternalTestgeneratorDSL.g:9749:2: rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_6__4__Impl();
+            pushFollow(FOLLOW_15);
+            rule__Test__Group_7_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__5();
+            rule__Test__Group_7_4__1();
 
             state._fsp--;
 
@@ -29917,46 +29603,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__4"
+    // $ANTLR end "rule__Test__Group_7_4__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__4__Impl"
-    // InternalTestgeneratorDSL.g:9777:1: rule__BusinessRuleTaskFlowElement__Group_6__4__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4__0__Impl"
+    // InternalTestgeneratorDSL.g:9756:1: rule__Test__Group_7_4__0__Impl : ( ( rule__Test__MocksAssignment_7_4_0 ) ) ;
+    public final void rule__Test__Group_7_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9781:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:9782:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )? )
+            // InternalTestgeneratorDSL.g:9760:1: ( ( ( rule__Test__MocksAssignment_7_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:9761:1: ( ( rule__Test__MocksAssignment_7_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:9782:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )? )
-            // InternalTestgeneratorDSL.g:9783:2: ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )?
+            // InternalTestgeneratorDSL.g:9761:1: ( ( rule__Test__MocksAssignment_7_4_0 ) )
+            // InternalTestgeneratorDSL.g:9762:2: ( rule__Test__MocksAssignment_7_4_0 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4()); 
-            // InternalTestgeneratorDSL.g:9784:2: ( rule__BusinessRuleTaskFlowElement__Group_6_4__0 )?
-            int alt77=2;
-            int LA77_0 = input.LA(1);
-
-            if ( (LA77_0==RULE_ID) ) {
-                alt77=1;
-            }
-            switch (alt77) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:9784:3: rule__BusinessRuleTaskFlowElement__Group_6_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_6_4__0();
-
-                    state._fsp--;
+             before(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); 
+            // InternalTestgeneratorDSL.g:9763:2: ( rule__Test__MocksAssignment_7_4_0 )
+            // InternalTestgeneratorDSL.g:9763:3: rule__Test__MocksAssignment_7_4_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__MocksAssignment_7_4_0();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4()); 
+             after(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); 
 
             }
 
@@ -29975,21 +29650,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__4__Impl"
+    // $ANTLR end "rule__Test__Group_7_4__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__5"
-    // InternalTestgeneratorDSL.g:9792:1: rule__BusinessRuleTaskFlowElement__Group_6__5 : rule__BusinessRuleTaskFlowElement__Group_6__5__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__5() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4__1"
+    // InternalTestgeneratorDSL.g:9771:1: rule__Test__Group_7_4__1 : rule__Test__Group_7_4__1__Impl ;
+    public final void rule__Test__Group_7_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9796:1: ( rule__BusinessRuleTaskFlowElement__Group_6__5__Impl )
-            // InternalTestgeneratorDSL.g:9797:2: rule__BusinessRuleTaskFlowElement__Group_6__5__Impl
+            // InternalTestgeneratorDSL.g:9775:1: ( rule__Test__Group_7_4__1__Impl )
+            // InternalTestgeneratorDSL.g:9776:2: rule__Test__Group_7_4__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6__5__Impl();
+            rule__Test__Group_7_4__1__Impl();
 
             state._fsp--;
 
@@ -30008,25 +29683,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__5"
+    // $ANTLR end "rule__Test__Group_7_4__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6__5__Impl"
-    // InternalTestgeneratorDSL.g:9803:1: rule__BusinessRuleTaskFlowElement__Group_6__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4__1__Impl"
+    // InternalTestgeneratorDSL.g:9782:1: rule__Test__Group_7_4__1__Impl : ( ( rule__Test__Group_7_4_1__0 )* ) ;
+    public final void rule__Test__Group_7_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9807:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:9808:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:9786:1: ( ( ( rule__Test__Group_7_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:9787:1: ( ( rule__Test__Group_7_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:9808:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:9809:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:9787:1: ( ( rule__Test__Group_7_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:9788:2: ( rule__Test__Group_7_4_1__0 )*
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5()); 
+             before(grammarAccess.getTestAccess().getGroup_7_4_1()); 
+            // InternalTestgeneratorDSL.g:9789:2: ( rule__Test__Group_7_4_1__0 )*
+            loop61:
+            do {
+                int alt61=2;
+                int LA61_0 = input.LA(1);
+
+                if ( (LA61_0==RULE_SEPARATOR) ) {
+                    alt61=1;
+                }
+
+
+                switch (alt61) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:9789:3: rule__Test__Group_7_4_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__Test__Group_7_4_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop61;
+                }
+            } while (true);
+
+             after(grammarAccess.getTestAccess().getGroup_7_4_1()); 
 
             }
 
@@ -30045,26 +29748,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6__5__Impl"
+    // $ANTLR end "rule__Test__Group_7_4__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4__0"
-    // InternalTestgeneratorDSL.g:9819:1: rule__BusinessRuleTaskFlowElement__Group_6_4__0 : rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4__0() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4_1__0"
+    // InternalTestgeneratorDSL.g:9798:1: rule__Test__Group_7_4_1__0 : rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1 ;
+    public final void rule__Test__Group_7_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9823:1: ( rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4__1 )
-            // InternalTestgeneratorDSL.g:9824:2: rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4__1
+            // InternalTestgeneratorDSL.g:9802:1: ( rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1 )
+            // InternalTestgeneratorDSL.g:9803:2: rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1
             {
-            pushFollow(FOLLOW_15);
-            rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__Test__Group_7_4_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6_4__1();
+            rule__Test__Group_7_4_1__1();
 
             state._fsp--;
 
@@ -30083,35 +29786,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4__0"
+    // $ANTLR end "rule__Test__Group_7_4_1__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl"
-    // InternalTestgeneratorDSL.g:9831:1: rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl : ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4_1__0__Impl"
+    // InternalTestgeneratorDSL.g:9810:1: rule__Test__Group_7_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__Test__Group_7_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9835:1: ( ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:9836:1: ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 ) )
+            // InternalTestgeneratorDSL.g:9814:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:9815:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:9836:1: ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 ) )
-            // InternalTestgeneratorDSL.g:9837:2: ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 )
+            // InternalTestgeneratorDSL.g:9815:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:9816:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_0()); 
-            // InternalTestgeneratorDSL.g:9838:2: ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 )
-            // InternalTestgeneratorDSL.g:9838:3: rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_0()); 
+             before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
 
             }
 
@@ -30130,21 +29823,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4__0__Impl"
+    // $ANTLR end "rule__Test__Group_7_4_1__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4__1"
-    // InternalTestgeneratorDSL.g:9846:1: rule__BusinessRuleTaskFlowElement__Group_6_4__1 : rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4__1() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4_1__1"
+    // InternalTestgeneratorDSL.g:9825:1: rule__Test__Group_7_4_1__1 : rule__Test__Group_7_4_1__1__Impl ;
+    public final void rule__Test__Group_7_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9850:1: ( rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl )
-            // InternalTestgeneratorDSL.g:9851:2: rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl
+            // InternalTestgeneratorDSL.g:9829:1: ( rule__Test__Group_7_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:9830:2: rule__Test__Group_7_4_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl();
+            rule__Test__Group_7_4_1__1__Impl();
 
             state._fsp--;
 
@@ -30163,53 +29856,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4__1"
+    // $ANTLR end "rule__Test__Group_7_4_1__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl"
-    // InternalTestgeneratorDSL.g:9857:1: rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )* ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__Test__Group_7_4_1__1__Impl"
+    // InternalTestgeneratorDSL.g:9836:1: rule__Test__Group_7_4_1__1__Impl : ( ( rule__Test__MocksAssignment_7_4_1_1 ) ) ;
+    public final void rule__Test__Group_7_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9861:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:9862:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:9840:1: ( ( ( rule__Test__MocksAssignment_7_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:9841:1: ( ( rule__Test__MocksAssignment_7_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:9862:1: ( ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:9863:2: ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )*
+            // InternalTestgeneratorDSL.g:9841:1: ( ( rule__Test__MocksAssignment_7_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:9842:2: ( rule__Test__MocksAssignment_7_4_1_1 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4_1()); 
-            // InternalTestgeneratorDSL.g:9864:2: ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 )*
-            loop78:
-            do {
-                int alt78=2;
-                int LA78_0 = input.LA(1);
-
-                if ( (LA78_0==RULE_SEPARATOR) ) {
-                    alt78=1;
-                }
-
-
-                switch (alt78) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:9864:3: rule__BusinessRuleTaskFlowElement__Group_6_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__BusinessRuleTaskFlowElement__Group_6_4_1__0();
-
-            	    state._fsp--;
+             before(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); 
+            // InternalTestgeneratorDSL.g:9843:2: ( rule__Test__MocksAssignment_7_4_1_1 )
+            // InternalTestgeneratorDSL.g:9843:3: rule__Test__MocksAssignment_7_4_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__Test__MocksAssignment_7_4_1_1();
 
+            state._fsp--;
 
-            	    }
-            	    break;
 
-            	default :
-            	    break loop78;
-                }
-            } while (true);
+            }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_6_4_1()); 
+             after(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); 
 
             }
 
@@ -30228,26 +29903,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4__1__Impl"
+    // $ANTLR end "rule__Test__Group_7_4_1__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4_1__0"
-    // InternalTestgeneratorDSL.g:9873:1: rule__BusinessRuleTaskFlowElement__Group_6_4_1__0 : rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4_1__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__0"
+    // InternalTestgeneratorDSL.g:9852:1: rule__VariableDeclarations__Group__0 : rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1 ;
+    public final void rule__VariableDeclarations__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9877:1: ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4_1__1 )
-            // InternalTestgeneratorDSL.g:9878:2: rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_6_4_1__1
+            // InternalTestgeneratorDSL.g:9856:1: ( rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1 )
+            // InternalTestgeneratorDSL.g:9857:2: rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1
             {
-            pushFollow(FOLLOW_4);
-            rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl();
+            pushFollow(FOLLOW_58);
+            rule__VariableDeclarations__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6_4_1__1();
+            rule__VariableDeclarations__Group__1();
 
             state._fsp--;
 
@@ -30266,25 +29941,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4_1__0"
+    // $ANTLR end "rule__VariableDeclarations__Group__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:9885:1: rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:9864:1: rule__VariableDeclarations__Group__0__Impl : ( 'with' ) ;
+    public final void rule__VariableDeclarations__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9889:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:9890:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:9868:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:9869:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:9890:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:9891:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:9869:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9870:2: 'with'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); 
 
             }
 
@@ -30303,21 +29978,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4_1__0__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4_1__1"
-    // InternalTestgeneratorDSL.g:9900:1: rule__BusinessRuleTaskFlowElement__Group_6_4_1__1 : rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__1"
+    // InternalTestgeneratorDSL.g:9879:1: rule__VariableDeclarations__Group__1 : rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2 ;
+    public final void rule__VariableDeclarations__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9904:1: ( rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:9905:2: rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:9883:1: ( rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2 )
+            // InternalTestgeneratorDSL.g:9884:2: rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2
             {
+            pushFollow(FOLLOW_52);
+            rule__VariableDeclarations__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl();
+            rule__VariableDeclarations__Group__2();
 
             state._fsp--;
 
@@ -30336,35 +30016,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4_1__1"
+    // $ANTLR end "rule__VariableDeclarations__Group__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:9911:1: rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:9891:1: rule__VariableDeclarations__Group__1__Impl : ( 'variables' ) ;
+    public final void rule__VariableDeclarations__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9915:1: ( ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:9916:1: ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:9895:1: ( ( 'variables' ) )
+            // InternalTestgeneratorDSL.g:9896:1: ( 'variables' )
             {
-            // InternalTestgeneratorDSL.g:9916:1: ( ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:9917:2: ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 )
+            // InternalTestgeneratorDSL.g:9896:1: ( 'variables' )
+            // InternalTestgeneratorDSL.g:9897:2: 'variables'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_1_1()); 
-            // InternalTestgeneratorDSL.g:9918:2: ( rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 )
-            // InternalTestgeneratorDSL.g:9918:3: rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesAssignment_6_4_1_1()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); 
+            match(input,75,FOLLOW_2); 
+             after(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); 
 
             }
 
@@ -30383,26 +30053,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_6_4_1__1__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__0"
-    // InternalTestgeneratorDSL.g:9927:1: rule__BusinessRuleTaskFlowElement__Group_7__0 : rule__BusinessRuleTaskFlowElement__Group_7__0__Impl rule__BusinessRuleTaskFlowElement__Group_7__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__0() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__2"
+    // InternalTestgeneratorDSL.g:9906:1: rule__VariableDeclarations__Group__2 : rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3 ;
+    public final void rule__VariableDeclarations__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9931:1: ( rule__BusinessRuleTaskFlowElement__Group_7__0__Impl rule__BusinessRuleTaskFlowElement__Group_7__1 )
-            // InternalTestgeneratorDSL.g:9932:2: rule__BusinessRuleTaskFlowElement__Group_7__0__Impl rule__BusinessRuleTaskFlowElement__Group_7__1
+            // InternalTestgeneratorDSL.g:9910:1: ( rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3 )
+            // InternalTestgeneratorDSL.g:9911:2: rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3
             {
-            pushFollow(FOLLOW_28);
-            rule__BusinessRuleTaskFlowElement__Group_7__0__Impl();
+            pushFollow(FOLLOW_4);
+            rule__VariableDeclarations__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__1();
+            rule__VariableDeclarations__Group__3();
 
             state._fsp--;
 
@@ -30421,25 +30091,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__0"
+    // $ANTLR end "rule__VariableDeclarations__Group__2"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:9939:1: rule__BusinessRuleTaskFlowElement__Group_7__0__Impl : ( 'with' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:9918:1: rule__VariableDeclarations__Group__2__Impl : ( 'for' ) ;
+    public final void rule__VariableDeclarations__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9943:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:9944:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:9922:1: ( ( 'for' ) )
+            // InternalTestgeneratorDSL.g:9923:1: ( 'for' )
             {
-            // InternalTestgeneratorDSL.g:9944:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:9945:2: 'with'
+            // InternalTestgeneratorDSL.g:9923:1: ( 'for' )
+            // InternalTestgeneratorDSL.g:9924:2: 'for'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_7_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_7_0()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); 
+            match(input,68,FOLLOW_2); 
+             after(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); 
 
             }
 
@@ -30458,26 +30128,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__0__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__2__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__1"
-    // InternalTestgeneratorDSL.g:9954:1: rule__BusinessRuleTaskFlowElement__Group_7__1 : rule__BusinessRuleTaskFlowElement__Group_7__1__Impl rule__BusinessRuleTaskFlowElement__Group_7__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__1() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__3"
+    // InternalTestgeneratorDSL.g:9933:1: rule__VariableDeclarations__Group__3 : rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4 ;
+    public final void rule__VariableDeclarations__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9958:1: ( rule__BusinessRuleTaskFlowElement__Group_7__1__Impl rule__BusinessRuleTaskFlowElement__Group_7__2 )
-            // InternalTestgeneratorDSL.g:9959:2: rule__BusinessRuleTaskFlowElement__Group_7__1__Impl rule__BusinessRuleTaskFlowElement__Group_7__2
+            // InternalTestgeneratorDSL.g:9937:1: ( rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4 )
+            // InternalTestgeneratorDSL.g:9938:2: rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4
             {
             pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group_7__1__Impl();
+            rule__VariableDeclarations__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__2();
+            rule__VariableDeclarations__Group__4();
 
             state._fsp--;
 
@@ -30496,25 +30166,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__1"
+    // $ANTLR end "rule__VariableDeclarations__Group__3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:9966:1: rule__BusinessRuleTaskFlowElement__Group_7__1__Impl : ( 'outputVariables' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:9945:1: rule__VariableDeclarations__Group__3__Impl : ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) ) ;
+    public final void rule__VariableDeclarations__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9970:1: ( ( 'outputVariables' ) )
-            // InternalTestgeneratorDSL.g:9971:1: ( 'outputVariables' )
+            // InternalTestgeneratorDSL.g:9949:1: ( ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) ) )
+            // InternalTestgeneratorDSL.g:9950:1: ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) )
             {
-            // InternalTestgeneratorDSL.g:9971:1: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:9972:2: 'outputVariables'
+            // InternalTestgeneratorDSL.g:9950:1: ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) )
+            // InternalTestgeneratorDSL.g:9951:2: ( rule__VariableDeclarations__TaskReferenceAssignment_3 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesKeyword_7_1()); 
-            match(input,42,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesKeyword_7_1()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); 
+            // InternalTestgeneratorDSL.g:9952:2: ( rule__VariableDeclarations__TaskReferenceAssignment_3 )
+            // InternalTestgeneratorDSL.g:9952:3: rule__VariableDeclarations__TaskReferenceAssignment_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__VariableDeclarations__TaskReferenceAssignment_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); 
 
             }
 
@@ -30533,26 +30213,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__1__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__3__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__2"
-    // InternalTestgeneratorDSL.g:9981:1: rule__BusinessRuleTaskFlowElement__Group_7__2 : rule__BusinessRuleTaskFlowElement__Group_7__2__Impl rule__BusinessRuleTaskFlowElement__Group_7__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__2() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__4"
+    // InternalTestgeneratorDSL.g:9960:1: rule__VariableDeclarations__Group__4 : rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5 ;
+    public final void rule__VariableDeclarations__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9985:1: ( rule__BusinessRuleTaskFlowElement__Group_7__2__Impl rule__BusinessRuleTaskFlowElement__Group_7__3 )
-            // InternalTestgeneratorDSL.g:9986:2: rule__BusinessRuleTaskFlowElement__Group_7__2__Impl rule__BusinessRuleTaskFlowElement__Group_7__3
+            // InternalTestgeneratorDSL.g:9964:1: ( rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5 )
+            // InternalTestgeneratorDSL.g:9965:2: rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5
             {
             pushFollow(FOLLOW_13);
-            rule__BusinessRuleTaskFlowElement__Group_7__2__Impl();
+            rule__VariableDeclarations__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__3();
+            rule__VariableDeclarations__Group__5();
 
             state._fsp--;
 
@@ -30571,25 +30251,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__2"
+    // $ANTLR end "rule__VariableDeclarations__Group__4"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__2__Impl"
-    // InternalTestgeneratorDSL.g:9993:1: rule__BusinessRuleTaskFlowElement__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:9972:1: rule__VariableDeclarations__Group__4__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__VariableDeclarations__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:9997:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:9998:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9976:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:9977:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:9998:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:9999:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:9977:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:9978:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); 
 
             }
 
@@ -30608,26 +30288,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__2__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__4__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__3"
-    // InternalTestgeneratorDSL.g:10008:1: rule__BusinessRuleTaskFlowElement__Group_7__3 : rule__BusinessRuleTaskFlowElement__Group_7__3__Impl rule__BusinessRuleTaskFlowElement__Group_7__4 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__3() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__5"
+    // InternalTestgeneratorDSL.g:9987:1: rule__VariableDeclarations__Group__5 : rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6 ;
+    public final void rule__VariableDeclarations__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10012:1: ( rule__BusinessRuleTaskFlowElement__Group_7__3__Impl rule__BusinessRuleTaskFlowElement__Group_7__4 )
-            // InternalTestgeneratorDSL.g:10013:2: rule__BusinessRuleTaskFlowElement__Group_7__3__Impl rule__BusinessRuleTaskFlowElement__Group_7__4
+            // InternalTestgeneratorDSL.g:9991:1: ( rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6 )
+            // InternalTestgeneratorDSL.g:9992:2: rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_7__3__Impl();
+            pushFollow(FOLLOW_20);
+            rule__VariableDeclarations__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__4();
+            rule__VariableDeclarations__Group__6();
 
             state._fsp--;
 
@@ -30646,25 +30326,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__3"
+    // $ANTLR end "rule__VariableDeclarations__Group__5"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__3__Impl"
-    // InternalTestgeneratorDSL.g:10020:1: rule__BusinessRuleTaskFlowElement__Group_7__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:9999:1: rule__VariableDeclarations__Group__5__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__VariableDeclarations__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10024:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:10025:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:10003:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:10004:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:10025:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:10026:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:10004:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:10005:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_7_3()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); 
             match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_7_3()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); 
 
             }
 
@@ -30683,26 +30363,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__3__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__5__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__4"
-    // InternalTestgeneratorDSL.g:10035:1: rule__BusinessRuleTaskFlowElement__Group_7__4 : rule__BusinessRuleTaskFlowElement__Group_7__4__Impl rule__BusinessRuleTaskFlowElement__Group_7__5 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__4() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__6"
+    // InternalTestgeneratorDSL.g:10014:1: rule__VariableDeclarations__Group__6 : rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7 ;
+    public final void rule__VariableDeclarations__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10039:1: ( rule__BusinessRuleTaskFlowElement__Group_7__4__Impl rule__BusinessRuleTaskFlowElement__Group_7__5 )
-            // InternalTestgeneratorDSL.g:10040:2: rule__BusinessRuleTaskFlowElement__Group_7__4__Impl rule__BusinessRuleTaskFlowElement__Group_7__5
+            // InternalTestgeneratorDSL.g:10018:1: ( rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7 )
+            // InternalTestgeneratorDSL.g:10019:2: rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7
             {
-            pushFollow(FOLLOW_21);
-            rule__BusinessRuleTaskFlowElement__Group_7__4__Impl();
+            pushFollow(FOLLOW_20);
+            rule__VariableDeclarations__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__5();
+            rule__VariableDeclarations__Group__7();
 
             state._fsp--;
 
@@ -30721,36 +30401,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__4"
+    // $ANTLR end "rule__VariableDeclarations__Group__6"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__4__Impl"
-    // InternalTestgeneratorDSL.g:10047:1: rule__BusinessRuleTaskFlowElement__Group_7__4__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )? ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:10026:1: rule__VariableDeclarations__Group__6__Impl : ( ( rule__VariableDeclarations__Group_6__0 )? ) ;
+    public final void rule__VariableDeclarations__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10051:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:10052:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )? )
+            // InternalTestgeneratorDSL.g:10030:1: ( ( ( rule__VariableDeclarations__Group_6__0 )? ) )
+            // InternalTestgeneratorDSL.g:10031:1: ( ( rule__VariableDeclarations__Group_6__0 )? )
             {
-            // InternalTestgeneratorDSL.g:10052:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )? )
-            // InternalTestgeneratorDSL.g:10053:2: ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )?
+            // InternalTestgeneratorDSL.g:10031:1: ( ( rule__VariableDeclarations__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:10032:2: ( rule__VariableDeclarations__Group_6__0 )?
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4()); 
-            // InternalTestgeneratorDSL.g:10054:2: ( rule__BusinessRuleTaskFlowElement__Group_7_4__0 )?
-            int alt79=2;
-            int LA79_0 = input.LA(1);
+             before(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); 
+            // InternalTestgeneratorDSL.g:10033:2: ( rule__VariableDeclarations__Group_6__0 )?
+            int alt62=2;
+            int LA62_0 = input.LA(1);
 
-            if ( (LA79_0==RULE_ID) ) {
-                alt79=1;
+            if ( (LA62_0==RULE_ID) ) {
+                alt62=1;
             }
-            switch (alt79) {
+            switch (alt62) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:10054:3: rule__BusinessRuleTaskFlowElement__Group_7_4__0
+                    // InternalTestgeneratorDSL.g:10033:3: rule__VariableDeclarations__Group_6__0
                     {
                     pushFollow(FOLLOW_2);
-                    rule__BusinessRuleTaskFlowElement__Group_7_4__0();
+                    rule__VariableDeclarations__Group_6__0();
 
                     state._fsp--;
 
@@ -30760,7 +30440,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); 
 
             }
 
@@ -30779,21 +30459,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__4__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__6__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__5"
-    // InternalTestgeneratorDSL.g:10062:1: rule__BusinessRuleTaskFlowElement__Group_7__5 : rule__BusinessRuleTaskFlowElement__Group_7__5__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__5() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__7"
+    // InternalTestgeneratorDSL.g:10041:1: rule__VariableDeclarations__Group__7 : rule__VariableDeclarations__Group__7__Impl ;
+    public final void rule__VariableDeclarations__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10066:1: ( rule__BusinessRuleTaskFlowElement__Group_7__5__Impl )
-            // InternalTestgeneratorDSL.g:10067:2: rule__BusinessRuleTaskFlowElement__Group_7__5__Impl
+            // InternalTestgeneratorDSL.g:10045:1: ( rule__VariableDeclarations__Group__7__Impl )
+            // InternalTestgeneratorDSL.g:10046:2: rule__VariableDeclarations__Group__7__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7__5__Impl();
+            rule__VariableDeclarations__Group__7__Impl();
 
             state._fsp--;
 
@@ -30812,25 +30492,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__5"
+    // $ANTLR end "rule__VariableDeclarations__Group__7"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7__5__Impl"
-    // InternalTestgeneratorDSL.g:10073:1: rule__BusinessRuleTaskFlowElement__Group_7__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:10052:1: rule__VariableDeclarations__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__VariableDeclarations__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10077:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:10078:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:10056:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:10057:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:10078:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:10079:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:10057:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:10058:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
             match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
 
             }
 
@@ -30849,26 +30529,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7__5__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group__7__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4__0"
-    // InternalTestgeneratorDSL.g:10089:1: rule__BusinessRuleTaskFlowElement__Group_7_4__0 : rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4__0() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6__0"
+    // InternalTestgeneratorDSL.g:10068:1: rule__VariableDeclarations__Group_6__0 : rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1 ;
+    public final void rule__VariableDeclarations__Group_6__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10093:1: ( rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4__1 )
-            // InternalTestgeneratorDSL.g:10094:2: rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4__1
+            // InternalTestgeneratorDSL.g:10072:1: ( rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1 )
+            // InternalTestgeneratorDSL.g:10073:2: rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1
             {
             pushFollow(FOLLOW_15);
-            rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl();
+            rule__VariableDeclarations__Group_6__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7_4__1();
+            rule__VariableDeclarations__Group_6__1();
 
             state._fsp--;
 
@@ -30887,35 +30567,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4__0"
+    // $ANTLR end "rule__VariableDeclarations__Group_6__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl"
-    // InternalTestgeneratorDSL.g:10101:1: rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl : ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6__0__Impl"
+    // InternalTestgeneratorDSL.g:10080:1: rule__VariableDeclarations__Group_6__0__Impl : ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) ) ;
+    public final void rule__VariableDeclarations__Group_6__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10105:1: ( ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:10106:1: ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 ) )
+            // InternalTestgeneratorDSL.g:10084:1: ( ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) ) )
+            // InternalTestgeneratorDSL.g:10085:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10106:1: ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 ) )
-            // InternalTestgeneratorDSL.g:10107:2: ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 )
+            // InternalTestgeneratorDSL.g:10085:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:10086:2: ( rule__VariableDeclarations__VariablesAssignment_6_0 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_0()); 
-            // InternalTestgeneratorDSL.g:10108:2: ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 )
-            // InternalTestgeneratorDSL.g:10108:3: rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0
+             before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); 
+            // InternalTestgeneratorDSL.g:10087:2: ( rule__VariableDeclarations__VariablesAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:10087:3: rule__VariableDeclarations__VariablesAssignment_6_0
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0();
+            rule__VariableDeclarations__VariablesAssignment_6_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_0()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); 
 
             }
 
@@ -30934,21 +30614,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4__0__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group_6__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4__1"
-    // InternalTestgeneratorDSL.g:10116:1: rule__BusinessRuleTaskFlowElement__Group_7_4__1 : rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4__1() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6__1"
+    // InternalTestgeneratorDSL.g:10095:1: rule__VariableDeclarations__Group_6__1 : rule__VariableDeclarations__Group_6__1__Impl ;
+    public final void rule__VariableDeclarations__Group_6__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10120:1: ( rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl )
-            // InternalTestgeneratorDSL.g:10121:2: rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl
+            // InternalTestgeneratorDSL.g:10099:1: ( rule__VariableDeclarations__Group_6__1__Impl )
+            // InternalTestgeneratorDSL.g:10100:2: rule__VariableDeclarations__Group_6__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl();
+            rule__VariableDeclarations__Group_6__1__Impl();
 
             state._fsp--;
 
@@ -30967,40 +30647,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4__1"
+    // $ANTLR end "rule__VariableDeclarations__Group_6__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl"
-    // InternalTestgeneratorDSL.g:10127:1: rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )* ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6__1__Impl"
+    // InternalTestgeneratorDSL.g:10106:1: rule__VariableDeclarations__Group_6__1__Impl : ( ( rule__VariableDeclarations__Group_6_1__0 )* ) ;
+    public final void rule__VariableDeclarations__Group_6__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10131:1: ( ( ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:10132:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:10110:1: ( ( ( rule__VariableDeclarations__Group_6_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:10111:1: ( ( rule__VariableDeclarations__Group_6_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:10132:1: ( ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:10133:2: ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )*
+            // InternalTestgeneratorDSL.g:10111:1: ( ( rule__VariableDeclarations__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:10112:2: ( rule__VariableDeclarations__Group_6_1__0 )*
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4_1()); 
-            // InternalTestgeneratorDSL.g:10134:2: ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 )*
-            loop80:
+             before(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); 
+            // InternalTestgeneratorDSL.g:10113:2: ( rule__VariableDeclarations__Group_6_1__0 )*
+            loop63:
             do {
-                int alt80=2;
-                int LA80_0 = input.LA(1);
+                int alt63=2;
+                int LA63_0 = input.LA(1);
 
-                if ( (LA80_0==RULE_SEPARATOR) ) {
-                    alt80=1;
+                if ( (LA63_0==RULE_SEPARATOR) ) {
+                    alt63=1;
                 }
 
 
-                switch (alt80) {
+                switch (alt63) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:10134:3: rule__BusinessRuleTaskFlowElement__Group_7_4_1__0
+            	    // InternalTestgeneratorDSL.g:10113:3: rule__VariableDeclarations__Group_6_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__BusinessRuleTaskFlowElement__Group_7_4_1__0();
+            	    rule__VariableDeclarations__Group_6_1__0();
 
             	    state._fsp--;
 
@@ -31009,11 +30689,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop80;
+            	    break loop63;
                 }
             } while (true);
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getGroup_7_4_1()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); 
 
             }
 
@@ -31032,26 +30712,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4__1__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group_6__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4_1__0"
-    // InternalTestgeneratorDSL.g:10143:1: rule__BusinessRuleTaskFlowElement__Group_7_4_1__0 : rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4_1__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4_1__0() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6_1__0"
+    // InternalTestgeneratorDSL.g:10122:1: rule__VariableDeclarations__Group_6_1__0 : rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1 ;
+    public final void rule__VariableDeclarations__Group_6_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10147:1: ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4_1__1 )
-            // InternalTestgeneratorDSL.g:10148:2: rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl rule__BusinessRuleTaskFlowElement__Group_7_4_1__1
+            // InternalTestgeneratorDSL.g:10126:1: ( rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1 )
+            // InternalTestgeneratorDSL.g:10127:2: rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1
             {
             pushFollow(FOLLOW_4);
-            rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl();
+            rule__VariableDeclarations__Group_6_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7_4_1__1();
+            rule__VariableDeclarations__Group_6_1__1();
 
             state._fsp--;
 
@@ -31070,25 +30750,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4_1__0"
+    // $ANTLR end "rule__VariableDeclarations__Group_6_1__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:10155:1: rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6_1__0__Impl"
+    // InternalTestgeneratorDSL.g:10134:1: rule__VariableDeclarations__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__VariableDeclarations__Group_6_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10159:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:10160:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:10138:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:10139:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:10160:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:10161:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:10139:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:10140:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
+             before(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
 
             }
 
@@ -31107,21 +30787,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4_1__0__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group_6_1__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4_1__1"
-    // InternalTestgeneratorDSL.g:10170:1: rule__BusinessRuleTaskFlowElement__Group_7_4_1__1 : rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4_1__1() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6_1__1"
+    // InternalTestgeneratorDSL.g:10149:1: rule__VariableDeclarations__Group_6_1__1 : rule__VariableDeclarations__Group_6_1__1__Impl ;
+    public final void rule__VariableDeclarations__Group_6_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10174:1: ( rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:10175:2: rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl
+            // InternalTestgeneratorDSL.g:10153:1: ( rule__VariableDeclarations__Group_6_1__1__Impl )
+            // InternalTestgeneratorDSL.g:10154:2: rule__VariableDeclarations__Group_6_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl();
+            rule__VariableDeclarations__Group_6_1__1__Impl();
 
             state._fsp--;
 
@@ -31140,35 +30820,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4_1__1"
+    // $ANTLR end "rule__VariableDeclarations__Group_6_1__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:10181:1: rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl : ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__VariableDeclarations__Group_6_1__1__Impl"
+    // InternalTestgeneratorDSL.g:10160:1: rule__VariableDeclarations__Group_6_1__1__Impl : ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) ) ;
+    public final void rule__VariableDeclarations__Group_6_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10185:1: ( ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:10186:1: ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:10164:1: ( ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:10165:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:10186:1: ( ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:10187:2: ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 )
+            // InternalTestgeneratorDSL.g:10165:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:10166:2: ( rule__VariableDeclarations__VariablesAssignment_6_1_1 )
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_1_1()); 
-            // InternalTestgeneratorDSL.g:10188:2: ( rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 )
-            // InternalTestgeneratorDSL.g:10188:3: rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1
+             before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); 
+            // InternalTestgeneratorDSL.g:10167:2: ( rule__VariableDeclarations__VariablesAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:10167:3: rule__VariableDeclarations__VariablesAssignment_6_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1();
+            rule__VariableDeclarations__VariablesAssignment_6_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesAssignment_7_4_1_1()); 
+             after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); 
 
             }
 
@@ -31187,26 +30867,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_7_4_1__1__Impl"
+    // $ANTLR end "rule__VariableDeclarations__Group_6_1__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__0"
-    // InternalTestgeneratorDSL.g:10197:1: rule__BusinessRuleTaskFlowElement__Group_8__0 : rule__BusinessRuleTaskFlowElement__Group_8__0__Impl rule__BusinessRuleTaskFlowElement__Group_8__1 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__0() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__0"
+    // InternalTestgeneratorDSL.g:10176:1: rule__EndChecks__Group__0 : rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1 ;
+    public final void rule__EndChecks__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10201:1: ( rule__BusinessRuleTaskFlowElement__Group_8__0__Impl rule__BusinessRuleTaskFlowElement__Group_8__1 )
-            // InternalTestgeneratorDSL.g:10202:2: rule__BusinessRuleTaskFlowElement__Group_8__0__Impl rule__BusinessRuleTaskFlowElement__Group_8__1
+            // InternalTestgeneratorDSL.g:10180:1: ( rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1 )
+            // InternalTestgeneratorDSL.g:10181:2: rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1
             {
-            pushFollow(FOLLOW_29);
-            rule__BusinessRuleTaskFlowElement__Group_8__0__Impl();
+            pushFollow(FOLLOW_59);
+            rule__EndChecks__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_8__1();
+            rule__EndChecks__Group__1();
 
             state._fsp--;
 
@@ -31225,25 +30905,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__0"
+    // $ANTLR end "rule__EndChecks__Group__0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__0__Impl"
-    // InternalTestgeneratorDSL.g:10209:1: rule__BusinessRuleTaskFlowElement__Group_8__0__Impl : ( 'and' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10188:1: rule__EndChecks__Group__0__Impl : ( 'with' ) ;
+    public final void rule__EndChecks__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10213:1: ( ( 'and' ) )
-            // InternalTestgeneratorDSL.g:10214:1: ( 'and' )
+            // InternalTestgeneratorDSL.g:10192:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:10193:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:10214:1: ( 'and' )
-            // InternalTestgeneratorDSL.g:10215:2: 'and'
+            // InternalTestgeneratorDSL.g:10193:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:10194:2: 'with'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_8_0()); 
-            match(input,43,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_8_0()); 
+             before(grammarAccess.getEndChecksAccess().getWithKeyword_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getEndChecksAccess().getWithKeyword_0()); 
 
             }
 
@@ -31262,26 +30942,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__0__Impl"
+    // $ANTLR end "rule__EndChecks__Group__0__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__1"
-    // InternalTestgeneratorDSL.g:10224:1: rule__BusinessRuleTaskFlowElement__Group_8__1 : rule__BusinessRuleTaskFlowElement__Group_8__1__Impl rule__BusinessRuleTaskFlowElement__Group_8__2 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__1() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__1"
+    // InternalTestgeneratorDSL.g:10203:1: rule__EndChecks__Group__1 : rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2 ;
+    public final void rule__EndChecks__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10228:1: ( rule__BusinessRuleTaskFlowElement__Group_8__1__Impl rule__BusinessRuleTaskFlowElement__Group_8__2 )
-            // InternalTestgeneratorDSL.g:10229:2: rule__BusinessRuleTaskFlowElement__Group_8__1__Impl rule__BusinessRuleTaskFlowElement__Group_8__2
+            // InternalTestgeneratorDSL.g:10207:1: ( rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2 )
+            // InternalTestgeneratorDSL.g:10208:2: rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2
             {
             pushFollow(FOLLOW_12);
-            rule__BusinessRuleTaskFlowElement__Group_8__1__Impl();
+            rule__EndChecks__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_8__2();
+            rule__EndChecks__Group__2();
 
             state._fsp--;
 
@@ -31300,25 +30980,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__1"
+    // $ANTLR end "rule__EndChecks__Group__1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__1__Impl"
-    // InternalTestgeneratorDSL.g:10236:1: rule__BusinessRuleTaskFlowElement__Group_8__1__Impl : ( 'label' ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10215:1: rule__EndChecks__Group__1__Impl : ( 'check' ) ;
+    public final void rule__EndChecks__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10240:1: ( ( 'label' ) )
-            // InternalTestgeneratorDSL.g:10241:1: ( 'label' )
+            // InternalTestgeneratorDSL.g:10219:1: ( ( 'check' ) )
+            // InternalTestgeneratorDSL.g:10220:1: ( 'check' )
             {
-            // InternalTestgeneratorDSL.g:10241:1: ( 'label' )
-            // InternalTestgeneratorDSL.g:10242:2: 'label'
+            // InternalTestgeneratorDSL.g:10220:1: ( 'check' )
+            // InternalTestgeneratorDSL.g:10221:2: 'check'
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_8_1()); 
-            match(input,44,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_8_1()); 
+             before(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); 
+            match(input,76,FOLLOW_2); 
+             after(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); 
 
             }
 
@@ -31337,26 +31017,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__1__Impl"
+    // $ANTLR end "rule__EndChecks__Group__1__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__2"
-    // InternalTestgeneratorDSL.g:10251:1: rule__BusinessRuleTaskFlowElement__Group_8__2 : rule__BusinessRuleTaskFlowElement__Group_8__2__Impl rule__BusinessRuleTaskFlowElement__Group_8__3 ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__2() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__2"
+    // InternalTestgeneratorDSL.g:10230:1: rule__EndChecks__Group__2 : rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3 ;
+    public final void rule__EndChecks__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10255:1: ( rule__BusinessRuleTaskFlowElement__Group_8__2__Impl rule__BusinessRuleTaskFlowElement__Group_8__3 )
-            // InternalTestgeneratorDSL.g:10256:2: rule__BusinessRuleTaskFlowElement__Group_8__2__Impl rule__BusinessRuleTaskFlowElement__Group_8__3
+            // InternalTestgeneratorDSL.g:10234:1: ( rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3 )
+            // InternalTestgeneratorDSL.g:10235:2: rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3
             {
-            pushFollow(FOLLOW_7);
-            rule__BusinessRuleTaskFlowElement__Group_8__2__Impl();
+            pushFollow(FOLLOW_13);
+            rule__EndChecks__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_8__3();
+            rule__EndChecks__Group__3();
 
             state._fsp--;
 
@@ -31375,25 +31055,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__2"
+    // $ANTLR end "rule__EndChecks__Group__2"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__2__Impl"
-    // InternalTestgeneratorDSL.g:10263:1: rule__BusinessRuleTaskFlowElement__Group_8__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10242:1: rule__EndChecks__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__EndChecks__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10267:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:10268:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10246:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:10247:1: ( RULE_ASSOCIATION )
             {
-            // InternalTestgeneratorDSL.g:10268:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:10269:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:10247:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10248:2: RULE_ASSOCIATION
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
+             before(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); 
             match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2()); 
+             after(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
@@ -31412,21 +31092,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__2__Impl"
+    // $ANTLR end "rule__EndChecks__Group__2__Impl"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__3"
-    // InternalTestgeneratorDSL.g:10278:1: rule__BusinessRuleTaskFlowElement__Group_8__3 : rule__BusinessRuleTaskFlowElement__Group_8__3__Impl ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__3() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__3"
+    // InternalTestgeneratorDSL.g:10257:1: rule__EndChecks__Group__3 : rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4 ;
+    public final void rule__EndChecks__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10282:1: ( rule__BusinessRuleTaskFlowElement__Group_8__3__Impl )
-            // InternalTestgeneratorDSL.g:10283:2: rule__BusinessRuleTaskFlowElement__Group_8__3__Impl
+            // InternalTestgeneratorDSL.g:10261:1: ( rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4 )
+            // InternalTestgeneratorDSL.g:10262:2: rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4
             {
+            pushFollow(FOLLOW_20);
+            rule__EndChecks__Group__3__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__Group_8__3__Impl();
+            rule__EndChecks__Group__4();
 
             state._fsp--;
 
@@ -31445,35 +31130,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__3"
+    // $ANTLR end "rule__EndChecks__Group__3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__Group_8__3__Impl"
-    // InternalTestgeneratorDSL.g:10289:1: rule__BusinessRuleTaskFlowElement__Group_8__3__Impl : ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 ) ) ;
-    public final void rule__BusinessRuleTaskFlowElement__Group_8__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:10269:1: rule__EndChecks__Group__3__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__EndChecks__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10293:1: ( ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 ) ) )
-            // InternalTestgeneratorDSL.g:10294:1: ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 ) )
+            // InternalTestgeneratorDSL.g:10273:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:10274:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:10294:1: ( ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 ) )
-            // InternalTestgeneratorDSL.g:10295:2: ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 )
+            // InternalTestgeneratorDSL.g:10274:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:10275:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_8_3()); 
-            // InternalTestgeneratorDSL.g:10296:2: ( rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 )
-            // InternalTestgeneratorDSL.g:10296:3: rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelAssignment_8_3()); 
+             before(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); 
 
             }
 
@@ -31492,26 +31167,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__Group_8__3__Impl"
+    // $ANTLR end "rule__EndChecks__Group__3__Impl"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:10305:1: rule__GatewayFlowElement__Group__0 : rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1 ;
-    public final void rule__GatewayFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__4"
+    // InternalTestgeneratorDSL.g:10284:1: rule__EndChecks__Group__4 : rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5 ;
+    public final void rule__EndChecks__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10309:1: ( rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:10310:2: rule__GatewayFlowElement__Group__0__Impl rule__GatewayFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:10288:1: ( rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5 )
+            // InternalTestgeneratorDSL.g:10289:2: rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5
             {
-            pushFollow(FOLLOW_4);
-            rule__GatewayFlowElement__Group__0__Impl();
+            pushFollow(FOLLOW_20);
+            rule__EndChecks__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__Group__1();
+            rule__EndChecks__Group__5();
 
             state._fsp--;
 
@@ -31530,25 +31205,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__0"
+    // $ANTLR end "rule__EndChecks__Group__4"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:10317:1: rule__GatewayFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__GatewayFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:10296:1: rule__EndChecks__Group__4__Impl : ( ( rule__EndChecks__Group_4__0 )? ) ;
+    public final void rule__EndChecks__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10321:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:10322:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:10300:1: ( ( ( rule__EndChecks__Group_4__0 )? ) )
+            // InternalTestgeneratorDSL.g:10301:1: ( ( rule__EndChecks__Group_4__0 )? )
             {
-            // InternalTestgeneratorDSL.g:10322:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:10323:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:10301:1: ( ( rule__EndChecks__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:10302:2: ( rule__EndChecks__Group_4__0 )?
             {
-             before(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getEndChecksAccess().getGroup_4()); 
+            // InternalTestgeneratorDSL.g:10303:2: ( rule__EndChecks__Group_4__0 )?
+            int alt64=2;
+            int LA64_0 = input.LA(1);
+
+            if ( (LA64_0==RULE_ID) ) {
+                alt64=1;
+            }
+            switch (alt64) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:10303:3: rule__EndChecks__Group_4__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__EndChecks__Group_4__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getEndChecksAccess().getGroup_4()); 
 
             }
 
@@ -31567,26 +31263,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__EndChecks__Group__4__Impl"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:10332:1: rule__GatewayFlowElement__Group__1 : rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2 ;
-    public final void rule__GatewayFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__5"
+    // InternalTestgeneratorDSL.g:10311:1: rule__EndChecks__Group__5 : rule__EndChecks__Group__5__Impl ;
+    public final void rule__EndChecks__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10336:1: ( rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:10337:2: rule__GatewayFlowElement__Group__1__Impl rule__GatewayFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:10315:1: ( rule__EndChecks__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:10316:2: rule__EndChecks__Group__5__Impl
             {
-            pushFollow(FOLLOW_12);
-            rule__GatewayFlowElement__Group__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__Group__2();
+            rule__EndChecks__Group__5__Impl();
 
             state._fsp--;
 
@@ -31605,35 +31296,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__1"
+    // $ANTLR end "rule__EndChecks__Group__5"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:10344:1: rule__GatewayFlowElement__Group__1__Impl : ( ( rule__GatewayFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__GatewayFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:10322:1: rule__EndChecks__Group__5__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__EndChecks__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10348:1: ( ( ( rule__GatewayFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:10349:1: ( ( rule__GatewayFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:10326:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:10327:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:10349:1: ( ( rule__GatewayFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:10350:2: ( rule__GatewayFlowElement__NameAssignment_1 )
-            {
-             before(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:10351:2: ( rule__GatewayFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:10351:3: rule__GatewayFlowElement__NameAssignment_1
+            // InternalTestgeneratorDSL.g:10327:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:10328:2: RULE_LIST_CLOSED
             {
-            pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getGatewayFlowElementAccess().getNameAssignment_1()); 
+             before(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); 
 
             }
 
@@ -31652,26 +31333,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__EndChecks__Group__5__Impl"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:10359:1: rule__GatewayFlowElement__Group__2 : rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3 ;
-    public final void rule__GatewayFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4__0"
+    // InternalTestgeneratorDSL.g:10338:1: rule__EndChecks__Group_4__0 : rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1 ;
+    public final void rule__EndChecks__Group_4__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10363:1: ( rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:10364:2: rule__GatewayFlowElement__Group__2__Impl rule__GatewayFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:10342:1: ( rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1 )
+            // InternalTestgeneratorDSL.g:10343:2: rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1
             {
-            pushFollow(FOLLOW_38);
-            rule__GatewayFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_15);
+            rule__EndChecks__Group_4__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__Group__3();
+            rule__EndChecks__Group_4__1();
 
             state._fsp--;
 
@@ -31690,25 +31371,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__2"
+    // $ANTLR end "rule__EndChecks__Group_4__0"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:10371:1: rule__GatewayFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__GatewayFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4__0__Impl"
+    // InternalTestgeneratorDSL.g:10350:1: rule__EndChecks__Group_4__0__Impl : ( ( rule__EndChecks__EndChecksAssignment_4_0 ) ) ;
+    public final void rule__EndChecks__Group_4__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10375:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:10376:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10354:1: ( ( ( rule__EndChecks__EndChecksAssignment_4_0 ) ) )
+            // InternalTestgeneratorDSL.g:10355:1: ( ( rule__EndChecks__EndChecksAssignment_4_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10376:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:10377:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:10355:1: ( ( rule__EndChecks__EndChecksAssignment_4_0 ) )
+            // InternalTestgeneratorDSL.g:10356:2: ( rule__EndChecks__EndChecksAssignment_4_0 )
             {
-             before(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); 
+            // InternalTestgeneratorDSL.g:10357:2: ( rule__EndChecks__EndChecksAssignment_4_0 )
+            // InternalTestgeneratorDSL.g:10357:3: rule__EndChecks__EndChecksAssignment_4_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__EndChecks__EndChecksAssignment_4_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); 
 
             }
 
@@ -31727,26 +31418,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__EndChecks__Group_4__0__Impl"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:10386:1: rule__GatewayFlowElement__Group__3 : rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4 ;
-    public final void rule__GatewayFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4__1"
+    // InternalTestgeneratorDSL.g:10365:1: rule__EndChecks__Group_4__1 : rule__EndChecks__Group_4__1__Impl ;
+    public final void rule__EndChecks__Group_4__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10390:1: ( rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:10391:2: rule__GatewayFlowElement__Group__3__Impl rule__GatewayFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:10369:1: ( rule__EndChecks__Group_4__1__Impl )
+            // InternalTestgeneratorDSL.g:10370:2: rule__EndChecks__Group_4__1__Impl
             {
-            pushFollow(FOLLOW_24);
-            rule__GatewayFlowElement__Group__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__Group__4();
+            rule__EndChecks__Group_4__1__Impl();
 
             state._fsp--;
 
@@ -31765,25 +31451,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__3"
+    // $ANTLR end "rule__EndChecks__Group_4__1"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:10398:1: rule__GatewayFlowElement__Group__3__Impl : ( 'Gateway' ) ;
-    public final void rule__GatewayFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4__1__Impl"
+    // InternalTestgeneratorDSL.g:10376:1: rule__EndChecks__Group_4__1__Impl : ( ( rule__EndChecks__Group_4_1__0 )* ) ;
+    public final void rule__EndChecks__Group_4__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10402:1: ( ( 'Gateway' ) )
-            // InternalTestgeneratorDSL.g:10403:1: ( 'Gateway' )
+            // InternalTestgeneratorDSL.g:10380:1: ( ( ( rule__EndChecks__Group_4_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:10381:1: ( ( rule__EndChecks__Group_4_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:10403:1: ( 'Gateway' )
-            // InternalTestgeneratorDSL.g:10404:2: 'Gateway'
+            // InternalTestgeneratorDSL.g:10381:1: ( ( rule__EndChecks__Group_4_1__0 )* )
+            // InternalTestgeneratorDSL.g:10382:2: ( rule__EndChecks__Group_4_1__0 )*
             {
-             before(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); 
-            match(input,52,FOLLOW_2); 
-             after(grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3()); 
+             before(grammarAccess.getEndChecksAccess().getGroup_4_1()); 
+            // InternalTestgeneratorDSL.g:10383:2: ( rule__EndChecks__Group_4_1__0 )*
+            loop65:
+            do {
+                int alt65=2;
+                int LA65_0 = input.LA(1);
+
+                if ( (LA65_0==RULE_SEPARATOR) ) {
+                    alt65=1;
+                }
+
+
+                switch (alt65) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:10383:3: rule__EndChecks__Group_4_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__EndChecks__Group_4_1__0();
+
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop65;
+                }
+            } while (true);
+
+             after(grammarAccess.getEndChecksAccess().getGroup_4_1()); 
 
             }
 
@@ -31802,21 +31516,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__EndChecks__Group_4__1__Impl"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:10413:1: rule__GatewayFlowElement__Group__4 : rule__GatewayFlowElement__Group__4__Impl ;
-    public final void rule__GatewayFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4_1__0"
+    // InternalTestgeneratorDSL.g:10392:1: rule__EndChecks__Group_4_1__0 : rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1 ;
+    public final void rule__EndChecks__Group_4_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10417:1: ( rule__GatewayFlowElement__Group__4__Impl )
-            // InternalTestgeneratorDSL.g:10418:2: rule__GatewayFlowElement__Group__4__Impl
+            // InternalTestgeneratorDSL.g:10396:1: ( rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1 )
+            // InternalTestgeneratorDSL.g:10397:2: rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1
             {
+            pushFollow(FOLLOW_4);
+            rule__EndChecks__Group_4_1__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__GatewayFlowElement__Group__4__Impl();
+            rule__EndChecks__Group_4_1__1();
 
             state._fsp--;
 
@@ -31835,25 +31554,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__4"
+    // $ANTLR end "rule__EndChecks__Group_4_1__0"
 
 
-    // $ANTLR start "rule__GatewayFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:10424:1: rule__GatewayFlowElement__Group__4__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__GatewayFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4_1__0__Impl"
+    // InternalTestgeneratorDSL.g:10404:1: rule__EndChecks__Group_4_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__EndChecks__Group_4_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10428:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:10429:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:10408:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:10409:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:10429:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:10430:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:10409:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:10410:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getGatewayFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_4()); 
+             before(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); 
 
             }
 
@@ -31872,26 +31591,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__GatewayFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__EndChecks__Group_4_1__0__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__0"
-    // InternalTestgeneratorDSL.g:10440:1: rule__SequenceFlowElement__Group__0 : rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1 ;
-    public final void rule__SequenceFlowElement__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4_1__1"
+    // InternalTestgeneratorDSL.g:10419:1: rule__EndChecks__Group_4_1__1 : rule__EndChecks__Group_4_1__1__Impl ;
+    public final void rule__EndChecks__Group_4_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10444:1: ( rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1 )
-            // InternalTestgeneratorDSL.g:10445:2: rule__SequenceFlowElement__Group__0__Impl rule__SequenceFlowElement__Group__1
+            // InternalTestgeneratorDSL.g:10423:1: ( rule__EndChecks__Group_4_1__1__Impl )
+            // InternalTestgeneratorDSL.g:10424:2: rule__EndChecks__Group_4_1__1__Impl
             {
-            pushFollow(FOLLOW_4);
-            rule__SequenceFlowElement__Group__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__1();
+            rule__EndChecks__Group_4_1__1__Impl();
 
             state._fsp--;
 
@@ -31910,25 +31624,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__0"
+    // $ANTLR end "rule__EndChecks__Group_4_1__1"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:10452:1: rule__SequenceFlowElement__Group__0__Impl : ( 'FlowElement' ) ;
-    public final void rule__SequenceFlowElement__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__EndChecks__Group_4_1__1__Impl"
+    // InternalTestgeneratorDSL.g:10430:1: rule__EndChecks__Group_4_1__1__Impl : ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) ) ;
+    public final void rule__EndChecks__Group_4_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10456:1: ( ( 'FlowElement' ) )
-            // InternalTestgeneratorDSL.g:10457:1: ( 'FlowElement' )
+            // InternalTestgeneratorDSL.g:10434:1: ( ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:10435:1: ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:10457:1: ( 'FlowElement' )
-            // InternalTestgeneratorDSL.g:10458:2: 'FlowElement'
+            // InternalTestgeneratorDSL.g:10435:1: ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) )
+            // InternalTestgeneratorDSL.g:10436:2: ( rule__EndChecks__EndChecksAssignment_4_1_1 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); 
-            match(input,34,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0()); 
+             before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); 
+            // InternalTestgeneratorDSL.g:10437:2: ( rule__EndChecks__EndChecksAssignment_4_1_1 )
+            // InternalTestgeneratorDSL.g:10437:3: rule__EndChecks__EndChecksAssignment_4_1_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__EndChecks__EndChecksAssignment_4_1_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); 
 
             }
 
@@ -31947,26 +31671,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__0__Impl"
+    // $ANTLR end "rule__EndChecks__Group_4_1__1__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__1"
-    // InternalTestgeneratorDSL.g:10467:1: rule__SequenceFlowElement__Group__1 : rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2 ;
-    public final void rule__SequenceFlowElement__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__0"
+    // InternalTestgeneratorDSL.g:10446:1: rule__StringVariableDeclaration__Group__0 : rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1 ;
+    public final void rule__StringVariableDeclaration__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10471:1: ( rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2 )
-            // InternalTestgeneratorDSL.g:10472:2: rule__SequenceFlowElement__Group__1__Impl rule__SequenceFlowElement__Group__2
+            // InternalTestgeneratorDSL.g:10450:1: ( rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1 )
+            // InternalTestgeneratorDSL.g:10451:2: rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1
             {
-            pushFollow(FOLLOW_12);
-            rule__SequenceFlowElement__Group__1__Impl();
+            pushFollow(FOLLOW_60);
+            rule__StringVariableDeclaration__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__2();
+            rule__StringVariableDeclaration__Group__1();
 
             state._fsp--;
 
@@ -31985,35 +31709,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__1"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__0"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:10479:1: rule__SequenceFlowElement__Group__1__Impl : ( ( rule__SequenceFlowElement__NameAssignment_1 ) ) ;
-    public final void rule__SequenceFlowElement__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10458:1: rule__StringVariableDeclaration__Group__0__Impl : ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) ) ;
+    public final void rule__StringVariableDeclaration__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10483:1: ( ( ( rule__SequenceFlowElement__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:10484:1: ( ( rule__SequenceFlowElement__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:10462:1: ( ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10463:1: ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10484:1: ( ( rule__SequenceFlowElement__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:10485:2: ( rule__SequenceFlowElement__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:10463:1: ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10464:2: ( rule__StringVariableDeclaration__KeyAssignment_0 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:10486:2: ( rule__SequenceFlowElement__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:10486:3: rule__SequenceFlowElement__NameAssignment_1
+             before(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10465:2: ( rule__StringVariableDeclaration__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10465:3: rule__StringVariableDeclaration__KeyAssignment_0
             {
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__NameAssignment_1();
+            rule__StringVariableDeclaration__KeyAssignment_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getSequenceFlowElementAccess().getNameAssignment_1()); 
+             after(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); 
 
             }
 
@@ -32032,26 +31756,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__1__Impl"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__0__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__2"
-    // InternalTestgeneratorDSL.g:10494:1: rule__SequenceFlowElement__Group__2 : rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3 ;
-    public final void rule__SequenceFlowElement__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__1"
+    // InternalTestgeneratorDSL.g:10473:1: rule__StringVariableDeclaration__Group__1 : rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2 ;
+    public final void rule__StringVariableDeclaration__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10498:1: ( rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3 )
-            // InternalTestgeneratorDSL.g:10499:2: rule__SequenceFlowElement__Group__2__Impl rule__SequenceFlowElement__Group__3
+            // InternalTestgeneratorDSL.g:10477:1: ( rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2 )
+            // InternalTestgeneratorDSL.g:10478:2: rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2
             {
-            pushFollow(FOLLOW_39);
-            rule__SequenceFlowElement__Group__2__Impl();
+            pushFollow(FOLLOW_7);
+            rule__StringVariableDeclaration__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__3();
+            rule__StringVariableDeclaration__Group__2();
 
             state._fsp--;
 
@@ -32070,25 +31794,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__2"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__1"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:10506:1: rule__SequenceFlowElement__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__SequenceFlowElement__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10485:1: rule__StringVariableDeclaration__Group__1__Impl : ( '=' ) ;
+    public final void rule__StringVariableDeclaration__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10510:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:10511:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10489:1: ( ( '=' ) )
+            // InternalTestgeneratorDSL.g:10490:1: ( '=' )
             {
-            // InternalTestgeneratorDSL.g:10511:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:10512:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:10490:1: ( '=' )
+            // InternalTestgeneratorDSL.g:10491:2: '='
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2()); 
+             before(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); 
+            match(input,77,FOLLOW_2); 
+             after(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); 
 
             }
 
@@ -32107,26 +31831,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__2__Impl"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__1__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__3"
-    // InternalTestgeneratorDSL.g:10521:1: rule__SequenceFlowElement__Group__3 : rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4 ;
-    public final void rule__SequenceFlowElement__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__2"
+    // InternalTestgeneratorDSL.g:10500:1: rule__StringVariableDeclaration__Group__2 : rule__StringVariableDeclaration__Group__2__Impl ;
+    public final void rule__StringVariableDeclaration__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10525:1: ( rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4 )
-            // InternalTestgeneratorDSL.g:10526:2: rule__SequenceFlowElement__Group__3__Impl rule__SequenceFlowElement__Group__4
+            // InternalTestgeneratorDSL.g:10504:1: ( rule__StringVariableDeclaration__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10505:2: rule__StringVariableDeclaration__Group__2__Impl
             {
-            pushFollow(FOLLOW_10);
-            rule__SequenceFlowElement__Group__3__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__4();
+            rule__StringVariableDeclaration__Group__2__Impl();
 
             state._fsp--;
 
@@ -32145,25 +31864,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__3"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__2"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:10533:1: rule__SequenceFlowElement__Group__3__Impl : ( 'SequenceFlow' ) ;
-    public final void rule__SequenceFlowElement__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableDeclaration__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10511:1: rule__StringVariableDeclaration__Group__2__Impl : ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) ) ;
+    public final void rule__StringVariableDeclaration__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10537:1: ( ( 'SequenceFlow' ) )
-            // InternalTestgeneratorDSL.g:10538:1: ( 'SequenceFlow' )
+            // InternalTestgeneratorDSL.g:10515:1: ( ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10516:1: ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10538:1: ( 'SequenceFlow' )
-            // InternalTestgeneratorDSL.g:10539:2: 'SequenceFlow'
+            // InternalTestgeneratorDSL.g:10516:1: ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10517:2: ( rule__StringVariableDeclaration__ValueAssignment_2 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); 
-            match(input,53,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3()); 
+             before(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10518:2: ( rule__StringVariableDeclaration__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10518:3: rule__StringVariableDeclaration__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariableDeclaration__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); 
 
             }
 
@@ -32182,26 +31911,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__3__Impl"
+    // $ANTLR end "rule__StringVariableDeclaration__Group__2__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__4"
-    // InternalTestgeneratorDSL.g:10548:1: rule__SequenceFlowElement__Group__4 : rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5 ;
-    public final void rule__SequenceFlowElement__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__0"
+    // InternalTestgeneratorDSL.g:10527:1: rule__IntVariableDeclaration__Group__0 : rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1 ;
+    public final void rule__IntVariableDeclaration__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10552:1: ( rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5 )
-            // InternalTestgeneratorDSL.g:10553:2: rule__SequenceFlowElement__Group__4__Impl rule__SequenceFlowElement__Group__5
+            // InternalTestgeneratorDSL.g:10531:1: ( rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1 )
+            // InternalTestgeneratorDSL.g:10532:2: rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1
             {
-            pushFollow(FOLLOW_10);
-            rule__SequenceFlowElement__Group__4__Impl();
+            pushFollow(FOLLOW_60);
+            rule__IntVariableDeclaration__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__5();
+            rule__IntVariableDeclaration__Group__1();
 
             state._fsp--;
 
@@ -32220,46 +31949,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__4"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__0"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:10560:1: rule__SequenceFlowElement__Group__4__Impl : ( ( rule__SequenceFlowElement__Group_4__0 )? ) ;
-    public final void rule__SequenceFlowElement__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10539:1: rule__IntVariableDeclaration__Group__0__Impl : ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) ) ;
+    public final void rule__IntVariableDeclaration__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10564:1: ( ( ( rule__SequenceFlowElement__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:10565:1: ( ( rule__SequenceFlowElement__Group_4__0 )? )
+            // InternalTestgeneratorDSL.g:10543:1: ( ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10544:1: ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10565:1: ( ( rule__SequenceFlowElement__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:10566:2: ( rule__SequenceFlowElement__Group_4__0 )?
+            // InternalTestgeneratorDSL.g:10544:1: ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10545:2: ( rule__IntVariableDeclaration__KeyAssignment_0 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:10567:2: ( rule__SequenceFlowElement__Group_4__0 )?
-            int alt81=2;
-            int LA81_0 = input.LA(1);
-
-            if ( (LA81_0==28) ) {
-                alt81=1;
-            }
-            switch (alt81) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:10567:3: rule__SequenceFlowElement__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__SequenceFlowElement__Group_4__0();
-
-                    state._fsp--;
+             before(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10546:2: ( rule__IntVariableDeclaration__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10546:3: rule__IntVariableDeclaration__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariableDeclaration__KeyAssignment_0();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getSequenceFlowElementAccess().getGroup_4()); 
+             after(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); 
 
             }
 
@@ -32278,21 +31996,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__4__Impl"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__0__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__5"
-    // InternalTestgeneratorDSL.g:10575:1: rule__SequenceFlowElement__Group__5 : rule__SequenceFlowElement__Group__5__Impl ;
-    public final void rule__SequenceFlowElement__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__1"
+    // InternalTestgeneratorDSL.g:10554:1: rule__IntVariableDeclaration__Group__1 : rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2 ;
+    public final void rule__IntVariableDeclaration__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10579:1: ( rule__SequenceFlowElement__Group__5__Impl )
-            // InternalTestgeneratorDSL.g:10580:2: rule__SequenceFlowElement__Group__5__Impl
+            // InternalTestgeneratorDSL.g:10558:1: ( rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2 )
+            // InternalTestgeneratorDSL.g:10559:2: rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2
             {
+            pushFollow(FOLLOW_42);
+            rule__IntVariableDeclaration__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group__5__Impl();
+            rule__IntVariableDeclaration__Group__2();
 
             state._fsp--;
 
@@ -32311,25 +32034,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__5"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__1"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:10586:1: rule__SequenceFlowElement__Group__5__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__SequenceFlowElement__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10566:1: rule__IntVariableDeclaration__Group__1__Impl : ( '=' ) ;
+    public final void rule__IntVariableDeclaration__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10590:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:10591:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:10570:1: ( ( '=' ) )
+            // InternalTestgeneratorDSL.g:10571:1: ( '=' )
             {
-            // InternalTestgeneratorDSL.g:10591:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:10592:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:10571:1: ( '=' )
+            // InternalTestgeneratorDSL.g:10572:2: '='
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5()); 
+             before(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); 
+            match(input,77,FOLLOW_2); 
+             after(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); 
 
             }
 
@@ -32348,26 +32071,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group__5__Impl"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__1__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__0"
-    // InternalTestgeneratorDSL.g:10602:1: rule__SequenceFlowElement__Group_4__0 : rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1 ;
-    public final void rule__SequenceFlowElement__Group_4__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__2"
+    // InternalTestgeneratorDSL.g:10581:1: rule__IntVariableDeclaration__Group__2 : rule__IntVariableDeclaration__Group__2__Impl ;
+    public final void rule__IntVariableDeclaration__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10606:1: ( rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1 )
-            // InternalTestgeneratorDSL.g:10607:2: rule__SequenceFlowElement__Group_4__0__Impl rule__SequenceFlowElement__Group_4__1
+            // InternalTestgeneratorDSL.g:10585:1: ( rule__IntVariableDeclaration__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10586:2: rule__IntVariableDeclaration__Group__2__Impl
             {
-            pushFollow(FOLLOW_40);
-            rule__SequenceFlowElement__Group_4__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group_4__1();
+            rule__IntVariableDeclaration__Group__2__Impl();
 
             state._fsp--;
 
@@ -32386,25 +32104,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__0"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__2"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:10614:1: rule__SequenceFlowElement__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__SequenceFlowElement__Group_4__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableDeclaration__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10592:1: rule__IntVariableDeclaration__Group__2__Impl : ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) ) ;
+    public final void rule__IntVariableDeclaration__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10618:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:10619:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:10596:1: ( ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10597:1: ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10619:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:10620:2: 'with'
+            // InternalTestgeneratorDSL.g:10597:1: ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10598:2: ( rule__IntVariableDeclaration__ValueAssignment_2 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0()); 
+             before(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10599:2: ( rule__IntVariableDeclaration__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10599:3: rule__IntVariableDeclaration__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariableDeclaration__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); 
 
             }
 
@@ -32423,26 +32151,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__0__Impl"
+    // $ANTLR end "rule__IntVariableDeclaration__Group__2__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__1"
-    // InternalTestgeneratorDSL.g:10629:1: rule__SequenceFlowElement__Group_4__1 : rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2 ;
-    public final void rule__SequenceFlowElement__Group_4__1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__0"
+    // InternalTestgeneratorDSL.g:10608:1: rule__BooleanVariableDeclaration__Group__0 : rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1 ;
+    public final void rule__BooleanVariableDeclaration__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10633:1: ( rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2 )
-            // InternalTestgeneratorDSL.g:10634:2: rule__SequenceFlowElement__Group_4__1__Impl rule__SequenceFlowElement__Group_4__2
+            // InternalTestgeneratorDSL.g:10612:1: ( rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1 )
+            // InternalTestgeneratorDSL.g:10613:2: rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1
             {
-            pushFollow(FOLLOW_12);
-            rule__SequenceFlowElement__Group_4__1__Impl();
+            pushFollow(FOLLOW_60);
+            rule__BooleanVariableDeclaration__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group_4__2();
+            rule__BooleanVariableDeclaration__Group__1();
 
             state._fsp--;
 
@@ -32461,25 +32189,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__1"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__0"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:10641:1: rule__SequenceFlowElement__Group_4__1__Impl : ( 'expression' ) ;
-    public final void rule__SequenceFlowElement__Group_4__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10620:1: rule__BooleanVariableDeclaration__Group__0__Impl : ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) ) ;
+    public final void rule__BooleanVariableDeclaration__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10645:1: ( ( 'expression' ) )
-            // InternalTestgeneratorDSL.g:10646:1: ( 'expression' )
+            // InternalTestgeneratorDSL.g:10624:1: ( ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10625:1: ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10646:1: ( 'expression' )
-            // InternalTestgeneratorDSL.g:10647:2: 'expression'
+            // InternalTestgeneratorDSL.g:10625:1: ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10626:2: ( rule__BooleanVariableDeclaration__KeyAssignment_0 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); 
-            match(input,54,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1()); 
+             before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10627:2: ( rule__BooleanVariableDeclaration__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10627:3: rule__BooleanVariableDeclaration__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariableDeclaration__KeyAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); 
 
             }
 
@@ -32498,26 +32236,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__1__Impl"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__0__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__2"
-    // InternalTestgeneratorDSL.g:10656:1: rule__SequenceFlowElement__Group_4__2 : rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3 ;
-    public final void rule__SequenceFlowElement__Group_4__2() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__1"
+    // InternalTestgeneratorDSL.g:10635:1: rule__BooleanVariableDeclaration__Group__1 : rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2 ;
+    public final void rule__BooleanVariableDeclaration__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10660:1: ( rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3 )
-            // InternalTestgeneratorDSL.g:10661:2: rule__SequenceFlowElement__Group_4__2__Impl rule__SequenceFlowElement__Group_4__3
+            // InternalTestgeneratorDSL.g:10639:1: ( rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2 )
+            // InternalTestgeneratorDSL.g:10640:2: rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2
             {
-            pushFollow(FOLLOW_7);
-            rule__SequenceFlowElement__Group_4__2__Impl();
+            pushFollow(FOLLOW_44);
+            rule__BooleanVariableDeclaration__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group_4__3();
+            rule__BooleanVariableDeclaration__Group__2();
 
             state._fsp--;
 
@@ -32536,25 +32274,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__2"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__1"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:10668:1: rule__SequenceFlowElement__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__SequenceFlowElement__Group_4__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10647:1: rule__BooleanVariableDeclaration__Group__1__Impl : ( '=' ) ;
+    public final void rule__BooleanVariableDeclaration__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10672:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:10673:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10651:1: ( ( '=' ) )
+            // InternalTestgeneratorDSL.g:10652:1: ( '=' )
             {
-            // InternalTestgeneratorDSL.g:10673:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:10674:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:10652:1: ( '=' )
+            // InternalTestgeneratorDSL.g:10653:2: '='
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
+             before(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); 
+            match(input,77,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); 
 
             }
 
@@ -32573,21 +32311,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__2__Impl"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__1__Impl"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__3"
-    // InternalTestgeneratorDSL.g:10683:1: rule__SequenceFlowElement__Group_4__3 : rule__SequenceFlowElement__Group_4__3__Impl ;
-    public final void rule__SequenceFlowElement__Group_4__3() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__2"
+    // InternalTestgeneratorDSL.g:10662:1: rule__BooleanVariableDeclaration__Group__2 : rule__BooleanVariableDeclaration__Group__2__Impl ;
+    public final void rule__BooleanVariableDeclaration__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10687:1: ( rule__SequenceFlowElement__Group_4__3__Impl )
-            // InternalTestgeneratorDSL.g:10688:2: rule__SequenceFlowElement__Group_4__3__Impl
+            // InternalTestgeneratorDSL.g:10666:1: ( rule__BooleanVariableDeclaration__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10667:2: rule__BooleanVariableDeclaration__Group__2__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__Group_4__3__Impl();
+            rule__BooleanVariableDeclaration__Group__2__Impl();
 
             state._fsp--;
 
@@ -32606,35 +32344,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__3"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__2"
 
 
-    // $ANTLR start "rule__SequenceFlowElement__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:10694:1: rule__SequenceFlowElement__Group_4__3__Impl : ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) ) ;
-    public final void rule__SequenceFlowElement__Group_4__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableDeclaration__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10673:1: rule__BooleanVariableDeclaration__Group__2__Impl : ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) ) ;
+    public final void rule__BooleanVariableDeclaration__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10698:1: ( ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) ) )
-            // InternalTestgeneratorDSL.g:10699:1: ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) )
+            // InternalTestgeneratorDSL.g:10677:1: ( ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10678:1: ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10699:1: ( ( rule__SequenceFlowElement__ExpressionAssignment_4_3 ) )
-            // InternalTestgeneratorDSL.g:10700:2: ( rule__SequenceFlowElement__ExpressionAssignment_4_3 )
+            // InternalTestgeneratorDSL.g:10678:1: ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10679:2: ( rule__BooleanVariableDeclaration__ValueAssignment_2 )
             {
-             before(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); 
-            // InternalTestgeneratorDSL.g:10701:2: ( rule__SequenceFlowElement__ExpressionAssignment_4_3 )
-            // InternalTestgeneratorDSL.g:10701:3: rule__SequenceFlowElement__ExpressionAssignment_4_3
+             before(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10680:2: ( rule__BooleanVariableDeclaration__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10680:3: rule__BooleanVariableDeclaration__ValueAssignment_2
             {
             pushFollow(FOLLOW_2);
-            rule__SequenceFlowElement__ExpressionAssignment_4_3();
+            rule__BooleanVariableDeclaration__ValueAssignment_2();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getSequenceFlowElementAccess().getExpressionAssignment_4_3()); 
+             after(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); 
 
             }
 
@@ -32653,26 +32391,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__SequenceFlowElement__Group_4__3__Impl"
+    // $ANTLR end "rule__BooleanVariableDeclaration__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__0"
-    // InternalTestgeneratorDSL.g:10710:1: rule__ExternalTopic__Group__0 : rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1 ;
-    public final void rule__ExternalTopic__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__0"
+    // InternalTestgeneratorDSL.g:10689:1: rule__StringVariableEquals__Group__0 : rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1 ;
+    public final void rule__StringVariableEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10714:1: ( rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1 )
-            // InternalTestgeneratorDSL.g:10715:2: rule__ExternalTopic__Group__0__Impl rule__ExternalTopic__Group__1
+            // InternalTestgeneratorDSL.g:10693:1: ( rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:10694:2: rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1
             {
-            pushFollow(FOLLOW_4);
-            rule__ExternalTopic__Group__0__Impl();
+            pushFollow(FOLLOW_61);
+            rule__StringVariableEquals__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalTopic__Group__1();
+            rule__StringVariableEquals__Group__1();
 
             state._fsp--;
 
@@ -32691,25 +32429,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__0"
+    // $ANTLR end "rule__StringVariableEquals__Group__0"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:10722:1: rule__ExternalTopic__Group__0__Impl : ( 'ExternalTopic' ) ;
-    public final void rule__ExternalTopic__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10701:1: rule__StringVariableEquals__Group__0__Impl : ( ( rule__StringVariableEquals__KeyAssignment_0 ) ) ;
+    public final void rule__StringVariableEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10726:1: ( ( 'ExternalTopic' ) )
-            // InternalTestgeneratorDSL.g:10727:1: ( 'ExternalTopic' )
+            // InternalTestgeneratorDSL.g:10705:1: ( ( ( rule__StringVariableEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10706:1: ( ( rule__StringVariableEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10727:1: ( 'ExternalTopic' )
-            // InternalTestgeneratorDSL.g:10728:2: 'ExternalTopic'
+            // InternalTestgeneratorDSL.g:10706:1: ( ( rule__StringVariableEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10707:2: ( rule__StringVariableEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); 
-            match(input,55,FOLLOW_2); 
-             after(grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0()); 
+             before(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10708:2: ( rule__StringVariableEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10708:3: rule__StringVariableEquals__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariableEquals__KeyAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -32728,26 +32476,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__0__Impl"
+    // $ANTLR end "rule__StringVariableEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__1"
-    // InternalTestgeneratorDSL.g:10737:1: rule__ExternalTopic__Group__1 : rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2 ;
-    public final void rule__ExternalTopic__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__1"
+    // InternalTestgeneratorDSL.g:10716:1: rule__StringVariableEquals__Group__1 : rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2 ;
+    public final void rule__StringVariableEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10741:1: ( rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2 )
-            // InternalTestgeneratorDSL.g:10742:2: rule__ExternalTopic__Group__1__Impl rule__ExternalTopic__Group__2
+            // InternalTestgeneratorDSL.g:10720:1: ( rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:10721:2: rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2
             {
-            pushFollow(FOLLOW_24);
-            rule__ExternalTopic__Group__1__Impl();
+            pushFollow(FOLLOW_7);
+            rule__StringVariableEquals__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ExternalTopic__Group__2();
+            rule__StringVariableEquals__Group__2();
 
             state._fsp--;
 
@@ -32766,35 +32514,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__1"
+    // $ANTLR end "rule__StringVariableEquals__Group__1"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:10749:1: rule__ExternalTopic__Group__1__Impl : ( ( rule__ExternalTopic__NameAssignment_1 ) ) ;
-    public final void rule__ExternalTopic__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10728:1: rule__StringVariableEquals__Group__1__Impl : ( '==' ) ;
+    public final void rule__StringVariableEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10753:1: ( ( ( rule__ExternalTopic__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:10754:1: ( ( rule__ExternalTopic__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:10732:1: ( ( '==' ) )
+            // InternalTestgeneratorDSL.g:10733:1: ( '==' )
             {
-            // InternalTestgeneratorDSL.g:10754:1: ( ( rule__ExternalTopic__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:10755:2: ( rule__ExternalTopic__NameAssignment_1 )
-            {
-             before(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:10756:2: ( rule__ExternalTopic__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:10756:3: rule__ExternalTopic__NameAssignment_1
+            // InternalTestgeneratorDSL.g:10733:1: ( '==' )
+            // InternalTestgeneratorDSL.g:10734:2: '=='
             {
-            pushFollow(FOLLOW_2);
-            rule__ExternalTopic__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalTopicAccess().getNameAssignment_1()); 
+             before(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
+            match(input,18,FOLLOW_2); 
+             after(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
 
             }
 
@@ -32813,21 +32551,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__1__Impl"
+    // $ANTLR end "rule__StringVariableEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__2"
-    // InternalTestgeneratorDSL.g:10764:1: rule__ExternalTopic__Group__2 : rule__ExternalTopic__Group__2__Impl ;
-    public final void rule__ExternalTopic__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__2"
+    // InternalTestgeneratorDSL.g:10743:1: rule__StringVariableEquals__Group__2 : rule__StringVariableEquals__Group__2__Impl ;
+    public final void rule__StringVariableEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10768:1: ( rule__ExternalTopic__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:10769:2: rule__ExternalTopic__Group__2__Impl
+            // InternalTestgeneratorDSL.g:10747:1: ( rule__StringVariableEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10748:2: rule__StringVariableEquals__Group__2__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__ExternalTopic__Group__2__Impl();
+            rule__StringVariableEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -32846,25 +32584,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__2"
+    // $ANTLR end "rule__StringVariableEquals__Group__2"
 
 
-    // $ANTLR start "rule__ExternalTopic__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:10775:1: rule__ExternalTopic__Group__2__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__ExternalTopic__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10754:1: rule__StringVariableEquals__Group__2__Impl : ( ( rule__StringVariableEquals__ValueAssignment_2 ) ) ;
+    public final void rule__StringVariableEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10779:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:10780:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:10758:1: ( ( ( rule__StringVariableEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10759:1: ( ( rule__StringVariableEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10780:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:10781:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:10759:1: ( ( rule__StringVariableEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10760:2: ( rule__StringVariableEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getExternalTopicAccess().getDECLARATION_FINISHEDTerminalRuleCall_2()); 
+             before(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10761:2: ( rule__StringVariableEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10761:3: rule__StringVariableEquals__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariableEquals__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -32883,26 +32631,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalTopic__Group__2__Impl"
+    // $ANTLR end "rule__StringVariableEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__0"
-    // InternalTestgeneratorDSL.g:10791:1: rule__StringVariable__Group__0 : rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1 ;
-    public final void rule__StringVariable__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__0"
+    // InternalTestgeneratorDSL.g:10770:1: rule__IntVariableEquals__Group__0 : rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1 ;
+    public final void rule__IntVariableEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10795:1: ( rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1 )
-            // InternalTestgeneratorDSL.g:10796:2: rule__StringVariable__Group__0__Impl rule__StringVariable__Group__1
+            // InternalTestgeneratorDSL.g:10774:1: ( rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:10775:2: rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1
             {
-            pushFollow(FOLLOW_4);
-            rule__StringVariable__Group__0__Impl();
+            pushFollow(FOLLOW_61);
+            rule__IntVariableEquals__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__1();
+            rule__IntVariableEquals__Group__1();
 
             state._fsp--;
 
@@ -32921,25 +32669,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__0"
+    // $ANTLR end "rule__IntVariableEquals__Group__0"
 
 
-    // $ANTLR start "rule__StringVariable__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:10803:1: rule__StringVariable__Group__0__Impl : ( 'String' ) ;
-    public final void rule__StringVariable__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10782:1: rule__IntVariableEquals__Group__0__Impl : ( ( rule__IntVariableEquals__KeyAssignment_0 ) ) ;
+    public final void rule__IntVariableEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10807:1: ( ( 'String' ) )
-            // InternalTestgeneratorDSL.g:10808:1: ( 'String' )
+            // InternalTestgeneratorDSL.g:10786:1: ( ( ( rule__IntVariableEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10787:1: ( ( rule__IntVariableEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10808:1: ( 'String' )
-            // InternalTestgeneratorDSL.g:10809:2: 'String'
+            // InternalTestgeneratorDSL.g:10787:1: ( ( rule__IntVariableEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10788:2: ( rule__IntVariableEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getStringVariableAccess().getStringKeyword_0()); 
-            match(input,56,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getStringKeyword_0()); 
+             before(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10789:2: ( rule__IntVariableEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10789:3: rule__IntVariableEquals__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariableEquals__KeyAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -32958,26 +32716,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__0__Impl"
+    // $ANTLR end "rule__IntVariableEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__1"
-    // InternalTestgeneratorDSL.g:10818:1: rule__StringVariable__Group__1 : rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2 ;
-    public final void rule__StringVariable__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__1"
+    // InternalTestgeneratorDSL.g:10797:1: rule__IntVariableEquals__Group__1 : rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2 ;
+    public final void rule__IntVariableEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10822:1: ( rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2 )
-            // InternalTestgeneratorDSL.g:10823:2: rule__StringVariable__Group__1__Impl rule__StringVariable__Group__2
+            // InternalTestgeneratorDSL.g:10801:1: ( rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:10802:2: rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2
             {
-            pushFollow(FOLLOW_5);
-            rule__StringVariable__Group__1__Impl();
+            pushFollow(FOLLOW_42);
+            rule__IntVariableEquals__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__2();
+            rule__IntVariableEquals__Group__2();
 
             state._fsp--;
 
@@ -32996,35 +32754,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__1"
+    // $ANTLR end "rule__IntVariableEquals__Group__1"
 
 
-    // $ANTLR start "rule__StringVariable__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:10830:1: rule__StringVariable__Group__1__Impl : ( ( rule__StringVariable__NameAssignment_1 ) ) ;
-    public final void rule__StringVariable__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10809:1: rule__IntVariableEquals__Group__1__Impl : ( '==' ) ;
+    public final void rule__IntVariableEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10834:1: ( ( ( rule__StringVariable__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:10835:1: ( ( rule__StringVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:10813:1: ( ( '==' ) )
+            // InternalTestgeneratorDSL.g:10814:1: ( '==' )
             {
-            // InternalTestgeneratorDSL.g:10835:1: ( ( rule__StringVariable__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:10836:2: ( rule__StringVariable__NameAssignment_1 )
-            {
-             before(grammarAccess.getStringVariableAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:10837:2: ( rule__StringVariable__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:10837:3: rule__StringVariable__NameAssignment_1
+            // InternalTestgeneratorDSL.g:10814:1: ( '==' )
+            // InternalTestgeneratorDSL.g:10815:2: '=='
             {
-            pushFollow(FOLLOW_2);
-            rule__StringVariable__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableAccess().getNameAssignment_1()); 
+             before(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
+            match(input,18,FOLLOW_2); 
+             after(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
 
             }
 
@@ -33043,26 +32791,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__1__Impl"
+    // $ANTLR end "rule__IntVariableEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__2"
-    // InternalTestgeneratorDSL.g:10845:1: rule__StringVariable__Group__2 : rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3 ;
-    public final void rule__StringVariable__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__2"
+    // InternalTestgeneratorDSL.g:10824:1: rule__IntVariableEquals__Group__2 : rule__IntVariableEquals__Group__2__Impl ;
+    public final void rule__IntVariableEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10849:1: ( rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3 )
-            // InternalTestgeneratorDSL.g:10850:2: rule__StringVariable__Group__2__Impl rule__StringVariable__Group__3
+            // InternalTestgeneratorDSL.g:10828:1: ( rule__IntVariableEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10829:2: rule__IntVariableEquals__Group__2__Impl
             {
-            pushFollow(FOLLOW_41);
-            rule__StringVariable__Group__2__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__3();
+            rule__IntVariableEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -33081,25 +32824,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__2"
+    // $ANTLR end "rule__IntVariableEquals__Group__2"
 
 
-    // $ANTLR start "rule__StringVariable__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:10857:1: rule__StringVariable__Group__2__Impl : ( 'with' ) ;
-    public final void rule__StringVariable__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10835:1: rule__IntVariableEquals__Group__2__Impl : ( ( rule__IntVariableEquals__ValueAssignment_2 ) ) ;
+    public final void rule__IntVariableEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10861:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:10862:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:10839:1: ( ( ( rule__IntVariableEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10840:1: ( ( rule__IntVariableEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10862:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:10863:2: 'with'
+            // InternalTestgeneratorDSL.g:10840:1: ( ( rule__IntVariableEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10841:2: ( rule__IntVariableEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getStringVariableAccess().getWithKeyword_2()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getWithKeyword_2()); 
+             before(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10842:2: ( rule__IntVariableEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10842:3: rule__IntVariableEquals__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariableEquals__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -33118,26 +32871,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__2__Impl"
+    // $ANTLR end "rule__IntVariableEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__3"
-    // InternalTestgeneratorDSL.g:10872:1: rule__StringVariable__Group__3 : rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4 ;
-    public final void rule__StringVariable__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__0"
+    // InternalTestgeneratorDSL.g:10851:1: rule__BooleanVariableEquals__Group__0 : rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1 ;
+    public final void rule__BooleanVariableEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10876:1: ( rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4 )
-            // InternalTestgeneratorDSL.g:10877:2: rule__StringVariable__Group__3__Impl rule__StringVariable__Group__4
+            // InternalTestgeneratorDSL.g:10855:1: ( rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:10856:2: rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1
             {
-            pushFollow(FOLLOW_12);
-            rule__StringVariable__Group__3__Impl();
+            pushFollow(FOLLOW_61);
+            rule__BooleanVariableEquals__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__4();
+            rule__BooleanVariableEquals__Group__1();
 
             state._fsp--;
 
@@ -33156,25 +32909,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__3"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__0"
 
 
-    // $ANTLR start "rule__StringVariable__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:10884:1: rule__StringVariable__Group__3__Impl : ( 'proposals' ) ;
-    public final void rule__StringVariable__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10863:1: rule__BooleanVariableEquals__Group__0__Impl : ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) ) ;
+    public final void rule__BooleanVariableEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10888:1: ( ( 'proposals' ) )
-            // InternalTestgeneratorDSL.g:10889:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:10867:1: ( ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10868:1: ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10889:1: ( 'proposals' )
-            // InternalTestgeneratorDSL.g:10890:2: 'proposals'
+            // InternalTestgeneratorDSL.g:10868:1: ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10869:2: ( rule__BooleanVariableEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); 
-            match(input,57,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getProposalsKeyword_3()); 
+             before(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10870:2: ( rule__BooleanVariableEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10870:3: rule__BooleanVariableEquals__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariableEquals__KeyAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -33193,26 +32956,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__3__Impl"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__4"
-    // InternalTestgeneratorDSL.g:10899:1: rule__StringVariable__Group__4 : rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5 ;
-    public final void rule__StringVariable__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__1"
+    // InternalTestgeneratorDSL.g:10878:1: rule__BooleanVariableEquals__Group__1 : rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2 ;
+    public final void rule__BooleanVariableEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10903:1: ( rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5 )
-            // InternalTestgeneratorDSL.g:10904:2: rule__StringVariable__Group__4__Impl rule__StringVariable__Group__5
+            // InternalTestgeneratorDSL.g:10882:1: ( rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:10883:2: rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2
             {
-            pushFollow(FOLLOW_13);
-            rule__StringVariable__Group__4__Impl();
+            pushFollow(FOLLOW_44);
+            rule__BooleanVariableEquals__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__5();
+            rule__BooleanVariableEquals__Group__2();
 
             state._fsp--;
 
@@ -33231,25 +32994,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__4"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__1"
 
 
-    // $ANTLR start "rule__StringVariable__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:10911:1: rule__StringVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__StringVariable__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10890:1: rule__BooleanVariableEquals__Group__1__Impl : ( '==' ) ;
+    public final void rule__BooleanVariableEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10915:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:10916:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:10894:1: ( ( '==' ) )
+            // InternalTestgeneratorDSL.g:10895:1: ( '==' )
             {
-            // InternalTestgeneratorDSL.g:10916:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:10917:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:10895:1: ( '==' )
+            // InternalTestgeneratorDSL.g:10896:2: '=='
             {
-             before(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
+             before(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
+            match(input,18,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
 
             }
 
@@ -33268,26 +33031,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__4__Impl"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__5"
-    // InternalTestgeneratorDSL.g:10926:1: rule__StringVariable__Group__5 : rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6 ;
-    public final void rule__StringVariable__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__2"
+    // InternalTestgeneratorDSL.g:10905:1: rule__BooleanVariableEquals__Group__2 : rule__BooleanVariableEquals__Group__2__Impl ;
+    public final void rule__BooleanVariableEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10930:1: ( rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6 )
-            // InternalTestgeneratorDSL.g:10931:2: rule__StringVariable__Group__5__Impl rule__StringVariable__Group__6
+            // InternalTestgeneratorDSL.g:10909:1: ( rule__BooleanVariableEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10910:2: rule__BooleanVariableEquals__Group__2__Impl
             {
-            pushFollow(FOLLOW_14);
-            rule__StringVariable__Group__5__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__6();
+            rule__BooleanVariableEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -33306,25 +33064,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__5"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__2"
 
 
-    // $ANTLR start "rule__StringVariable__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:10938:1: rule__StringVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__StringVariable__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10916:1: rule__BooleanVariableEquals__Group__2__Impl : ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) ) ;
+    public final void rule__BooleanVariableEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10942:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:10943:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:10920:1: ( ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:10921:1: ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:10943:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:10944:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:10921:1: ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:10922:2: ( rule__BooleanVariableEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
+             before(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:10923:2: ( rule__BooleanVariableEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:10923:3: rule__BooleanVariableEquals__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanVariableEquals__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -33343,26 +33111,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__5__Impl"
+    // $ANTLR end "rule__BooleanVariableEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__6"
-    // InternalTestgeneratorDSL.g:10953:1: rule__StringVariable__Group__6 : rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7 ;
-    public final void rule__StringVariable__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__0"
+    // InternalTestgeneratorDSL.g:10932:1: rule__StringVariableNotEquals__Group__0 : rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1 ;
+    public final void rule__StringVariableNotEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10957:1: ( rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7 )
-            // InternalTestgeneratorDSL.g:10958:2: rule__StringVariable__Group__6__Impl rule__StringVariable__Group__7
+            // InternalTestgeneratorDSL.g:10936:1: ( rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:10937:2: rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1
             {
-            pushFollow(FOLLOW_14);
-            rule__StringVariable__Group__6__Impl();
+            pushFollow(FOLLOW_62);
+            rule__StringVariableNotEquals__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__7();
+            rule__StringVariableNotEquals__Group__1();
 
             state._fsp--;
 
@@ -33381,46 +33149,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__6"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__0"
 
 
-    // $ANTLR start "rule__StringVariable__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:10965:1: rule__StringVariable__Group__6__Impl : ( ( rule__StringVariable__Group_6__0 )? ) ;
-    public final void rule__StringVariable__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:10944:1: rule__StringVariableNotEquals__Group__0__Impl : ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) ) ;
+    public final void rule__StringVariableNotEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10969:1: ( ( ( rule__StringVariable__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:10970:1: ( ( rule__StringVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:10948:1: ( ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:10949:1: ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:10970:1: ( ( rule__StringVariable__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:10971:2: ( rule__StringVariable__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:10949:1: ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:10950:2: ( rule__StringVariableNotEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getStringVariableAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:10972:2: ( rule__StringVariable__Group_6__0 )?
-            int alt82=2;
-            int LA82_0 = input.LA(1);
-
-            if ( (LA82_0==RULE_STRING) ) {
-                alt82=1;
-            }
-            switch (alt82) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:10972:3: rule__StringVariable__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__StringVariable__Group_6__0();
-
-                    state._fsp--;
+             before(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:10951:2: ( rule__StringVariableNotEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:10951:3: rule__StringVariableNotEquals__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariableNotEquals__KeyAssignment_0();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getStringVariableAccess().getGroup_6()); 
+             after(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -33439,26 +33196,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__6__Impl"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__7"
-    // InternalTestgeneratorDSL.g:10980:1: rule__StringVariable__Group__7 : rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8 ;
-    public final void rule__StringVariable__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__1"
+    // InternalTestgeneratorDSL.g:10959:1: rule__StringVariableNotEquals__Group__1 : rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2 ;
+    public final void rule__StringVariableNotEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10984:1: ( rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8 )
-            // InternalTestgeneratorDSL.g:10985:2: rule__StringVariable__Group__7__Impl rule__StringVariable__Group__8
+            // InternalTestgeneratorDSL.g:10963:1: ( rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:10964:2: rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2
             {
-            pushFollow(FOLLOW_24);
-            rule__StringVariable__Group__7__Impl();
+            pushFollow(FOLLOW_7);
+            rule__StringVariableNotEquals__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__8();
+            rule__StringVariableNotEquals__Group__2();
 
             state._fsp--;
 
@@ -33477,25 +33234,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__7"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__1"
 
 
-    // $ANTLR start "rule__StringVariable__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:10992:1: rule__StringVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__StringVariable__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:10971:1: rule__StringVariableNotEquals__Group__1__Impl : ( '!=' ) ;
+    public final void rule__StringVariableNotEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:10996:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:10997:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:10975:1: ( ( '!=' ) )
+            // InternalTestgeneratorDSL.g:10976:1: ( '!=' )
             {
-            // InternalTestgeneratorDSL.g:10997:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:10998:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:10976:1: ( '!=' )
+            // InternalTestgeneratorDSL.g:10977:2: '!='
             {
-             before(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+             before(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
+            match(input,19,FOLLOW_2); 
+             after(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
 
             }
 
@@ -33514,21 +33271,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__7__Impl"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group__8"
-    // InternalTestgeneratorDSL.g:11007:1: rule__StringVariable__Group__8 : rule__StringVariable__Group__8__Impl ;
-    public final void rule__StringVariable__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__2"
+    // InternalTestgeneratorDSL.g:10986:1: rule__StringVariableNotEquals__Group__2 : rule__StringVariableNotEquals__Group__2__Impl ;
+    public final void rule__StringVariableNotEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11011:1: ( rule__StringVariable__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:11012:2: rule__StringVariable__Group__8__Impl
+            // InternalTestgeneratorDSL.g:10990:1: ( rule__StringVariableNotEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:10991:2: rule__StringVariableNotEquals__Group__2__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group__8__Impl();
+            rule__StringVariableNotEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -33547,25 +33304,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__8"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__2"
 
 
-    // $ANTLR start "rule__StringVariable__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:11018:1: rule__StringVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__StringVariable__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__StringVariableNotEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:10997:1: rule__StringVariableNotEquals__Group__2__Impl : ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) ) ;
+    public final void rule__StringVariableNotEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11022:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:11023:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:11001:1: ( ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:11002:1: ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:11023:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:11024:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:11002:1: ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:11003:2: ( rule__StringVariableNotEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             before(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:11004:2: ( rule__StringVariableNotEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:11004:3: rule__StringVariableNotEquals__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__StringVariableNotEquals__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -33584,26 +33351,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group__8__Impl"
+    // $ANTLR end "rule__StringVariableNotEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6__0"
-    // InternalTestgeneratorDSL.g:11034:1: rule__StringVariable__Group_6__0 : rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1 ;
-    public final void rule__StringVariable__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__0"
+    // InternalTestgeneratorDSL.g:11013:1: rule__IntVariableNotEquals__Group__0 : rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1 ;
+    public final void rule__IntVariableNotEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11038:1: ( rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1 )
-            // InternalTestgeneratorDSL.g:11039:2: rule__StringVariable__Group_6__0__Impl rule__StringVariable__Group_6__1
+            // InternalTestgeneratorDSL.g:11017:1: ( rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:11018:2: rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1
             {
-            pushFollow(FOLLOW_15);
-            rule__StringVariable__Group_6__0__Impl();
+            pushFollow(FOLLOW_62);
+            rule__IntVariableNotEquals__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group_6__1();
+            rule__IntVariableNotEquals__Group__1();
 
             state._fsp--;
 
@@ -33622,35 +33389,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6__0"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__0"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:11046:1: rule__StringVariable__Group_6__0__Impl : ( ( rule__StringVariable__ProposalsAssignment_6_0 ) ) ;
-    public final void rule__StringVariable__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:11025:1: rule__IntVariableNotEquals__Group__0__Impl : ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) ) ;
+    public final void rule__IntVariableNotEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11050:1: ( ( ( rule__StringVariable__ProposalsAssignment_6_0 ) ) )
-            // InternalTestgeneratorDSL.g:11051:1: ( ( rule__StringVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:11029:1: ( ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:11030:1: ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:11051:1: ( ( rule__StringVariable__ProposalsAssignment_6_0 ) )
-            // InternalTestgeneratorDSL.g:11052:2: ( rule__StringVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:11030:1: ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:11031:2: ( rule__IntVariableNotEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); 
-            // InternalTestgeneratorDSL.g:11053:2: ( rule__StringVariable__ProposalsAssignment_6_0 )
-            // InternalTestgeneratorDSL.g:11053:3: rule__StringVariable__ProposalsAssignment_6_0
+             before(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:11032:2: ( rule__IntVariableNotEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:11032:3: rule__IntVariableNotEquals__KeyAssignment_0
             {
             pushFollow(FOLLOW_2);
-            rule__StringVariable__ProposalsAssignment_6_0();
+            rule__IntVariableNotEquals__KeyAssignment_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_0()); 
+             after(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -33669,21 +33436,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6__0__Impl"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6__1"
-    // InternalTestgeneratorDSL.g:11061:1: rule__StringVariable__Group_6__1 : rule__StringVariable__Group_6__1__Impl ;
-    public final void rule__StringVariable__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__1"
+    // InternalTestgeneratorDSL.g:11040:1: rule__IntVariableNotEquals__Group__1 : rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2 ;
+    public final void rule__IntVariableNotEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11065:1: ( rule__StringVariable__Group_6__1__Impl )
-            // InternalTestgeneratorDSL.g:11066:2: rule__StringVariable__Group_6__1__Impl
+            // InternalTestgeneratorDSL.g:11044:1: ( rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:11045:2: rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2
             {
+            pushFollow(FOLLOW_42);
+            rule__IntVariableNotEquals__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group_6__1__Impl();
+            rule__IntVariableNotEquals__Group__2();
 
             state._fsp--;
 
@@ -33702,53 +33474,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6__1"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__1"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:11072:1: rule__StringVariable__Group_6__1__Impl : ( ( rule__StringVariable__Group_6_1__0 )* ) ;
-    public final void rule__StringVariable__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:11052:1: rule__IntVariableNotEquals__Group__1__Impl : ( '!=' ) ;
+    public final void rule__IntVariableNotEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11076:1: ( ( ( rule__StringVariable__Group_6_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:11077:1: ( ( rule__StringVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:11056:1: ( ( '!=' ) )
+            // InternalTestgeneratorDSL.g:11057:1: ( '!=' )
             {
-            // InternalTestgeneratorDSL.g:11077:1: ( ( rule__StringVariable__Group_6_1__0 )* )
-            // InternalTestgeneratorDSL.g:11078:2: ( rule__StringVariable__Group_6_1__0 )*
+            // InternalTestgeneratorDSL.g:11057:1: ( '!=' )
+            // InternalTestgeneratorDSL.g:11058:2: '!='
             {
-             before(grammarAccess.getStringVariableAccess().getGroup_6_1()); 
-            // InternalTestgeneratorDSL.g:11079:2: ( rule__StringVariable__Group_6_1__0 )*
-            loop83:
-            do {
-                int alt83=2;
-                int LA83_0 = input.LA(1);
-
-                if ( (LA83_0==RULE_SEPARATOR) ) {
-                    alt83=1;
-                }
-
-
-                switch (alt83) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:11079:3: rule__StringVariable__Group_6_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__StringVariable__Group_6_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop83;
-                }
-            } while (true);
-
-             after(grammarAccess.getStringVariableAccess().getGroup_6_1()); 
+             before(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
+            match(input,19,FOLLOW_2); 
+             after(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
 
             }
 
@@ -33767,26 +33511,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6__1__Impl"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6_1__0"
-    // InternalTestgeneratorDSL.g:11088:1: rule__StringVariable__Group_6_1__0 : rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1 ;
-    public final void rule__StringVariable__Group_6_1__0() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__2"
+    // InternalTestgeneratorDSL.g:11067:1: rule__IntVariableNotEquals__Group__2 : rule__IntVariableNotEquals__Group__2__Impl ;
+    public final void rule__IntVariableNotEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11092:1: ( rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1 )
-            // InternalTestgeneratorDSL.g:11093:2: rule__StringVariable__Group_6_1__0__Impl rule__StringVariable__Group_6_1__1
+            // InternalTestgeneratorDSL.g:11071:1: ( rule__IntVariableNotEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:11072:2: rule__IntVariableNotEquals__Group__2__Impl
             {
-            pushFollow(FOLLOW_7);
-            rule__StringVariable__Group_6_1__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group_6_1__1();
+            rule__IntVariableNotEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -33805,25 +33544,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6_1__0"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__2"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6_1__0__Impl"
-    // InternalTestgeneratorDSL.g:11100:1: rule__StringVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__StringVariable__Group_6_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__IntVariableNotEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:11078:1: rule__IntVariableNotEquals__Group__2__Impl : ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) ) ;
+    public final void rule__IntVariableNotEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11104:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:11105:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11082:1: ( ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:11083:1: ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:11105:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:11106:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:11083:1: ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:11084:2: ( rule__IntVariableNotEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+             before(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:11085:2: ( rule__IntVariableNotEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:11085:3: rule__IntVariableNotEquals__ValueAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntVariableNotEquals__ValueAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -33842,21 +33591,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6_1__0__Impl"
+    // $ANTLR end "rule__IntVariableNotEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6_1__1"
-    // InternalTestgeneratorDSL.g:11115:1: rule__StringVariable__Group_6_1__1 : rule__StringVariable__Group_6_1__1__Impl ;
-    public final void rule__StringVariable__Group_6_1__1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__0"
+    // InternalTestgeneratorDSL.g:11094:1: rule__BooleanVariableNotEquals__Group__0 : rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1 ;
+    public final void rule__BooleanVariableNotEquals__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11119:1: ( rule__StringVariable__Group_6_1__1__Impl )
-            // InternalTestgeneratorDSL.g:11120:2: rule__StringVariable__Group_6_1__1__Impl
+            // InternalTestgeneratorDSL.g:11098:1: ( rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1 )
+            // InternalTestgeneratorDSL.g:11099:2: rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1
             {
+            pushFollow(FOLLOW_62);
+            rule__BooleanVariableNotEquals__Group__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__StringVariable__Group_6_1__1__Impl();
+            rule__BooleanVariableNotEquals__Group__1();
 
             state._fsp--;
 
@@ -33875,35 +33629,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6_1__1"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__0"
 
 
-    // $ANTLR start "rule__StringVariable__Group_6_1__1__Impl"
-    // InternalTestgeneratorDSL.g:11126:1: rule__StringVariable__Group_6_1__1__Impl : ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) ) ;
-    public final void rule__StringVariable__Group_6_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:11106:1: rule__BooleanVariableNotEquals__Group__0__Impl : ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) ) ;
+    public final void rule__BooleanVariableNotEquals__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11130:1: ( ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:11131:1: ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:11110:1: ( ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:11111:1: ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:11131:1: ( ( rule__StringVariable__ProposalsAssignment_6_1_1 ) )
-            // InternalTestgeneratorDSL.g:11132:2: ( rule__StringVariable__ProposalsAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:11111:1: ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:11112:2: ( rule__BooleanVariableNotEquals__KeyAssignment_0 )
             {
-             before(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); 
-            // InternalTestgeneratorDSL.g:11133:2: ( rule__StringVariable__ProposalsAssignment_6_1_1 )
-            // InternalTestgeneratorDSL.g:11133:3: rule__StringVariable__ProposalsAssignment_6_1_1
+             before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:11113:2: ( rule__BooleanVariableNotEquals__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:11113:3: rule__BooleanVariableNotEquals__KeyAssignment_0
             {
             pushFollow(FOLLOW_2);
-            rule__StringVariable__ProposalsAssignment_6_1_1();
+            rule__BooleanVariableNotEquals__KeyAssignment_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getStringVariableAccess().getProposalsAssignment_6_1_1()); 
+             after(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); 
 
             }
 
@@ -33922,26 +33676,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringVariable__Group_6_1__1__Impl"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__0__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__0"
-    // InternalTestgeneratorDSL.g:11142:1: rule__IntVariable__Group__0 : rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1 ;
-    public final void rule__IntVariable__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__1"
+    // InternalTestgeneratorDSL.g:11121:1: rule__BooleanVariableNotEquals__Group__1 : rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2 ;
+    public final void rule__BooleanVariableNotEquals__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11146:1: ( rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1 )
-            // InternalTestgeneratorDSL.g:11147:2: rule__IntVariable__Group__0__Impl rule__IntVariable__Group__1
+            // InternalTestgeneratorDSL.g:11125:1: ( rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2 )
+            // InternalTestgeneratorDSL.g:11126:2: rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2
             {
-            pushFollow(FOLLOW_4);
-            rule__IntVariable__Group__0__Impl();
+            pushFollow(FOLLOW_44);
+            rule__BooleanVariableNotEquals__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__1();
+            rule__BooleanVariableNotEquals__Group__2();
 
             state._fsp--;
 
@@ -33960,25 +33714,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__0"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__1"
 
 
-    // $ANTLR start "rule__IntVariable__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:11154:1: rule__IntVariable__Group__0__Impl : ( 'Integer' ) ;
-    public final void rule__IntVariable__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:11133:1: rule__BooleanVariableNotEquals__Group__1__Impl : ( '!=' ) ;
+    public final void rule__BooleanVariableNotEquals__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11158:1: ( ( 'Integer' ) )
-            // InternalTestgeneratorDSL.g:11159:1: ( 'Integer' )
+            // InternalTestgeneratorDSL.g:11137:1: ( ( '!=' ) )
+            // InternalTestgeneratorDSL.g:11138:1: ( '!=' )
             {
-            // InternalTestgeneratorDSL.g:11159:1: ( 'Integer' )
-            // InternalTestgeneratorDSL.g:11160:2: 'Integer'
+            // InternalTestgeneratorDSL.g:11138:1: ( '!=' )
+            // InternalTestgeneratorDSL.g:11139:2: '!='
             {
-             before(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); 
-            match(input,58,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getIntegerKeyword_0()); 
+             before(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
+            match(input,19,FOLLOW_2); 
+             after(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
 
             }
 
@@ -33997,26 +33751,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__0__Impl"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__1__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__1"
-    // InternalTestgeneratorDSL.g:11169:1: rule__IntVariable__Group__1 : rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2 ;
-    public final void rule__IntVariable__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__2"
+    // InternalTestgeneratorDSL.g:11148:1: rule__BooleanVariableNotEquals__Group__2 : rule__BooleanVariableNotEquals__Group__2__Impl ;
+    public final void rule__BooleanVariableNotEquals__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11173:1: ( rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2 )
-            // InternalTestgeneratorDSL.g:11174:2: rule__IntVariable__Group__1__Impl rule__IntVariable__Group__2
+            // InternalTestgeneratorDSL.g:11152:1: ( rule__BooleanVariableNotEquals__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:11153:2: rule__BooleanVariableNotEquals__Group__2__Impl
             {
-            pushFollow(FOLLOW_5);
-            rule__IntVariable__Group__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__2();
+            rule__BooleanVariableNotEquals__Group__2__Impl();
 
             state._fsp--;
 
@@ -34035,35 +33784,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__1"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__2"
 
 
-    // $ANTLR start "rule__IntVariable__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:11181:1: rule__IntVariable__Group__1__Impl : ( ( rule__IntVariable__NameAssignment_1 ) ) ;
-    public final void rule__IntVariable__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__BooleanVariableNotEquals__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:11159:1: rule__BooleanVariableNotEquals__Group__2__Impl : ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) ) ;
+    public final void rule__BooleanVariableNotEquals__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11185:1: ( ( ( rule__IntVariable__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:11186:1: ( ( rule__IntVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:11163:1: ( ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:11164:1: ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:11186:1: ( ( rule__IntVariable__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:11187:2: ( rule__IntVariable__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:11164:1: ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:11165:2: ( rule__BooleanVariableNotEquals__ValueAssignment_2 )
             {
-             before(grammarAccess.getIntVariableAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:11188:2: ( rule__IntVariable__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:11188:3: rule__IntVariable__NameAssignment_1
+             before(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:11166:2: ( rule__BooleanVariableNotEquals__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:11166:3: rule__BooleanVariableNotEquals__ValueAssignment_2
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__NameAssignment_1();
+            rule__BooleanVariableNotEquals__ValueAssignment_2();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getIntVariableAccess().getNameAssignment_1()); 
+             after(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); 
 
             }
 
@@ -34082,26 +33831,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__1__Impl"
+    // $ANTLR end "rule__BooleanVariableNotEquals__Group__2__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__2"
-    // InternalTestgeneratorDSL.g:11196:1: rule__IntVariable__Group__2 : rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3 ;
-    public final void rule__IntVariable__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__0"
+    // InternalTestgeneratorDSL.g:11175:1: rule__ExternalServiceMock__Group__0 : rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1 ;
+    public final void rule__ExternalServiceMock__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11200:1: ( rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3 )
-            // InternalTestgeneratorDSL.g:11201:2: rule__IntVariable__Group__2__Impl rule__IntVariable__Group__3
+            // InternalTestgeneratorDSL.g:11179:1: ( rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1 )
+            // InternalTestgeneratorDSL.g:11180:2: rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1
             {
-            pushFollow(FOLLOW_41);
-            rule__IntVariable__Group__2__Impl();
+            pushFollow(FOLLOW_4);
+            rule__ExternalServiceMock__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__3();
+            rule__ExternalServiceMock__Group__1();
 
             state._fsp--;
 
@@ -34120,25 +33869,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__2"
+    // $ANTLR end "rule__ExternalServiceMock__Group__0"
 
 
-    // $ANTLR start "rule__IntVariable__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:11208:1: rule__IntVariable__Group__2__Impl : ( 'with' ) ;
-    public final void rule__IntVariable__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:11187:1: rule__ExternalServiceMock__Group__0__Impl : ( 'ExternalServiceMock' ) ;
+    public final void rule__ExternalServiceMock__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11212:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:11213:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:11191:1: ( ( 'ExternalServiceMock' ) )
+            // InternalTestgeneratorDSL.g:11192:1: ( 'ExternalServiceMock' )
             {
-            // InternalTestgeneratorDSL.g:11213:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:11214:2: 'with'
+            // InternalTestgeneratorDSL.g:11192:1: ( 'ExternalServiceMock' )
+            // InternalTestgeneratorDSL.g:11193:2: 'ExternalServiceMock'
             {
-             before(grammarAccess.getIntVariableAccess().getWithKeyword_2()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getWithKeyword_2()); 
+             before(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); 
+            match(input,78,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); 
 
             }
 
@@ -34157,26 +33906,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__2__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__0__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__3"
-    // InternalTestgeneratorDSL.g:11223:1: rule__IntVariable__Group__3 : rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4 ;
-    public final void rule__IntVariable__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__1"
+    // InternalTestgeneratorDSL.g:11202:1: rule__ExternalServiceMock__Group__1 : rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2 ;
+    public final void rule__ExternalServiceMock__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11227:1: ( rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4 )
-            // InternalTestgeneratorDSL.g:11228:2: rule__IntVariable__Group__3__Impl rule__IntVariable__Group__4
+            // InternalTestgeneratorDSL.g:11206:1: ( rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2 )
+            // InternalTestgeneratorDSL.g:11207:2: rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2
             {
-            pushFollow(FOLLOW_12);
-            rule__IntVariable__Group__3__Impl();
+            pushFollow(FOLLOW_52);
+            rule__ExternalServiceMock__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__4();
+            rule__ExternalServiceMock__Group__2();
 
             state._fsp--;
 
@@ -34195,25 +33944,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__3"
+    // $ANTLR end "rule__ExternalServiceMock__Group__1"
 
 
-    // $ANTLR start "rule__IntVariable__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:11235:1: rule__IntVariable__Group__3__Impl : ( 'proposals' ) ;
-    public final void rule__IntVariable__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:11214:1: rule__ExternalServiceMock__Group__1__Impl : ( ( rule__ExternalServiceMock__NameAssignment_1 ) ) ;
+    public final void rule__ExternalServiceMock__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11239:1: ( ( 'proposals' ) )
-            // InternalTestgeneratorDSL.g:11240:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:11218:1: ( ( ( rule__ExternalServiceMock__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:11219:1: ( ( rule__ExternalServiceMock__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:11240:1: ( 'proposals' )
-            // InternalTestgeneratorDSL.g:11241:2: 'proposals'
+            // InternalTestgeneratorDSL.g:11219:1: ( ( rule__ExternalServiceMock__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:11220:2: ( rule__ExternalServiceMock__NameAssignment_1 )
             {
-             before(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); 
-            match(input,57,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getProposalsKeyword_3()); 
+             before(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:11221:2: ( rule__ExternalServiceMock__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:11221:3: rule__ExternalServiceMock__NameAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__ExternalServiceMock__NameAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); 
 
             }
 
@@ -34232,26 +33991,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__3__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__1__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__4"
-    // InternalTestgeneratorDSL.g:11250:1: rule__IntVariable__Group__4 : rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5 ;
-    public final void rule__IntVariable__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__2"
+    // InternalTestgeneratorDSL.g:11229:1: rule__ExternalServiceMock__Group__2 : rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3 ;
+    public final void rule__ExternalServiceMock__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11254:1: ( rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5 )
-            // InternalTestgeneratorDSL.g:11255:2: rule__IntVariable__Group__4__Impl rule__IntVariable__Group__5
+            // InternalTestgeneratorDSL.g:11233:1: ( rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3 )
+            // InternalTestgeneratorDSL.g:11234:2: rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3
             {
-            pushFollow(FOLLOW_13);
-            rule__IntVariable__Group__4__Impl();
+            pushFollow(FOLLOW_63);
+            rule__ExternalServiceMock__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__5();
+            rule__ExternalServiceMock__Group__3();
 
             state._fsp--;
 
@@ -34270,25 +34029,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__4"
+    // $ANTLR end "rule__ExternalServiceMock__Group__2"
 
 
-    // $ANTLR start "rule__IntVariable__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:11262:1: rule__IntVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__IntVariable__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:11241:1: rule__ExternalServiceMock__Group__2__Impl : ( 'for' ) ;
+    public final void rule__ExternalServiceMock__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11266:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:11267:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:11245:1: ( ( 'for' ) )
+            // InternalTestgeneratorDSL.g:11246:1: ( 'for' )
             {
-            // InternalTestgeneratorDSL.g:11267:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:11268:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:11246:1: ( 'for' )
+            // InternalTestgeneratorDSL.g:11247:2: 'for'
             {
-             before(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
+             before(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); 
+            match(input,68,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); 
 
             }
 
@@ -34307,26 +34066,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__4__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__2__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__5"
-    // InternalTestgeneratorDSL.g:11277:1: rule__IntVariable__Group__5 : rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6 ;
-    public final void rule__IntVariable__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__3"
+    // InternalTestgeneratorDSL.g:11256:1: rule__ExternalServiceMock__Group__3 : rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4 ;
+    public final void rule__ExternalServiceMock__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11281:1: ( rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6 )
-            // InternalTestgeneratorDSL.g:11282:2: rule__IntVariable__Group__5__Impl rule__IntVariable__Group__6
+            // InternalTestgeneratorDSL.g:11260:1: ( rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4 )
+            // InternalTestgeneratorDSL.g:11261:2: rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4
             {
-            pushFollow(FOLLOW_42);
-            rule__IntVariable__Group__5__Impl();
+            pushFollow(FOLLOW_4);
+            rule__ExternalServiceMock__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__6();
+            rule__ExternalServiceMock__Group__4();
 
             state._fsp--;
 
@@ -34345,25 +34104,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__5"
+    // $ANTLR end "rule__ExternalServiceMock__Group__3"
 
 
-    // $ANTLR start "rule__IntVariable__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:11289:1: rule__IntVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__IntVariable__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:11268:1: rule__ExternalServiceMock__Group__3__Impl : ( 'topic' ) ;
+    public final void rule__ExternalServiceMock__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11293:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:11294:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:11272:1: ( ( 'topic' ) )
+            // InternalTestgeneratorDSL.g:11273:1: ( 'topic' )
             {
-            // InternalTestgeneratorDSL.g:11294:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:11295:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:11273:1: ( 'topic' )
+            // InternalTestgeneratorDSL.g:11274:2: 'topic'
             {
-             before(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
+             before(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); 
+            match(input,79,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); 
 
             }
 
@@ -34382,26 +34141,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__5__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__3__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__6"
-    // InternalTestgeneratorDSL.g:11304:1: rule__IntVariable__Group__6 : rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7 ;
-    public final void rule__IntVariable__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__4"
+    // InternalTestgeneratorDSL.g:11283:1: rule__ExternalServiceMock__Group__4 : rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5 ;
+    public final void rule__ExternalServiceMock__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11308:1: ( rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7 )
-            // InternalTestgeneratorDSL.g:11309:2: rule__IntVariable__Group__6__Impl rule__IntVariable__Group__7
+            // InternalTestgeneratorDSL.g:11287:1: ( rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5 )
+            // InternalTestgeneratorDSL.g:11288:2: rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5
             {
-            pushFollow(FOLLOW_42);
-            rule__IntVariable__Group__6__Impl();
+            pushFollow(FOLLOW_10);
+            rule__ExternalServiceMock__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__7();
+            rule__ExternalServiceMock__Group__5();
 
             state._fsp--;
 
@@ -34420,46 +34179,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__6"
+    // $ANTLR end "rule__ExternalServiceMock__Group__4"
 
 
-    // $ANTLR start "rule__IntVariable__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:11316:1: rule__IntVariable__Group__6__Impl : ( ( rule__IntVariable__Group_6__0 )? ) ;
-    public final void rule__IntVariable__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:11295:1: rule__ExternalServiceMock__Group__4__Impl : ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) ) ;
+    public final void rule__ExternalServiceMock__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11320:1: ( ( ( rule__IntVariable__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:11321:1: ( ( rule__IntVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:11299:1: ( ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) ) )
+            // InternalTestgeneratorDSL.g:11300:1: ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) )
             {
-            // InternalTestgeneratorDSL.g:11321:1: ( ( rule__IntVariable__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:11322:2: ( rule__IntVariable__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:11300:1: ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) )
+            // InternalTestgeneratorDSL.g:11301:2: ( rule__ExternalServiceMock__ExternalTopicAssignment_4 )
             {
-             before(grammarAccess.getIntVariableAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:11323:2: ( rule__IntVariable__Group_6__0 )?
-            int alt84=2;
-            int LA84_0 = input.LA(1);
-
-            if ( (LA84_0==RULE_INT) ) {
-                alt84=1;
-            }
-            switch (alt84) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:11323:3: rule__IntVariable__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__IntVariable__Group_6__0();
-
-                    state._fsp--;
+             before(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); 
+            // InternalTestgeneratorDSL.g:11302:2: ( rule__ExternalServiceMock__ExternalTopicAssignment_4 )
+            // InternalTestgeneratorDSL.g:11302:3: rule__ExternalServiceMock__ExternalTopicAssignment_4
+            {
+            pushFollow(FOLLOW_2);
+            rule__ExternalServiceMock__ExternalTopicAssignment_4();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getIntVariableAccess().getGroup_6()); 
+             after(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); 
 
             }
 
@@ -34478,26 +34226,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__6__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__4__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__7"
-    // InternalTestgeneratorDSL.g:11331:1: rule__IntVariable__Group__7 : rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8 ;
-    public final void rule__IntVariable__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__5"
+    // InternalTestgeneratorDSL.g:11310:1: rule__ExternalServiceMock__Group__5 : rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6 ;
+    public final void rule__ExternalServiceMock__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11335:1: ( rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8 )
-            // InternalTestgeneratorDSL.g:11336:2: rule__IntVariable__Group__7__Impl rule__IntVariable__Group__8
+            // InternalTestgeneratorDSL.g:11314:1: ( rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6 )
+            // InternalTestgeneratorDSL.g:11315:2: rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6
             {
-            pushFollow(FOLLOW_24);
-            rule__IntVariable__Group__7__Impl();
+            pushFollow(FOLLOW_10);
+            rule__ExternalServiceMock__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__8();
+            rule__ExternalServiceMock__Group__6();
 
             state._fsp--;
 
@@ -34516,25 +34264,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__7"
+    // $ANTLR end "rule__ExternalServiceMock__Group__5"
 
 
-    // $ANTLR start "rule__IntVariable__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:11343:1: rule__IntVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__IntVariable__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:11322:1: rule__ExternalServiceMock__Group__5__Impl : ( ( rule__ExternalServiceMock__Group_5__0 )? ) ;
+    public final void rule__ExternalServiceMock__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11347:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:11348:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:11326:1: ( ( ( rule__ExternalServiceMock__Group_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:11327:1: ( ( rule__ExternalServiceMock__Group_5__0 )? )
             {
-            // InternalTestgeneratorDSL.g:11348:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:11349:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:11327:1: ( ( rule__ExternalServiceMock__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:11328:2: ( rule__ExternalServiceMock__Group_5__0 )?
             {
-             before(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+             before(grammarAccess.getExternalServiceMockAccess().getGroup_5()); 
+            // InternalTestgeneratorDSL.g:11329:2: ( rule__ExternalServiceMock__Group_5__0 )?
+            int alt66=2;
+            int LA66_0 = input.LA(1);
+
+            if ( (LA66_0==29) ) {
+                alt66=1;
+            }
+            switch (alt66) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:11329:3: rule__ExternalServiceMock__Group_5__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__ExternalServiceMock__Group_5__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getExternalServiceMockAccess().getGroup_5()); 
 
             }
 
@@ -34553,21 +34322,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__7__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__5__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group__8"
-    // InternalTestgeneratorDSL.g:11358:1: rule__IntVariable__Group__8 : rule__IntVariable__Group__8__Impl ;
-    public final void rule__IntVariable__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__6"
+    // InternalTestgeneratorDSL.g:11337:1: rule__ExternalServiceMock__Group__6 : rule__ExternalServiceMock__Group__6__Impl ;
+    public final void rule__ExternalServiceMock__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11362:1: ( rule__IntVariable__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:11363:2: rule__IntVariable__Group__8__Impl
+            // InternalTestgeneratorDSL.g:11341:1: ( rule__ExternalServiceMock__Group__6__Impl )
+            // InternalTestgeneratorDSL.g:11342:2: rule__ExternalServiceMock__Group__6__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group__8__Impl();
+            rule__ExternalServiceMock__Group__6__Impl();
 
             state._fsp--;
 
@@ -34586,25 +34355,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__8"
+    // $ANTLR end "rule__ExternalServiceMock__Group__6"
 
 
-    // $ANTLR start "rule__IntVariable__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:11369:1: rule__IntVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__IntVariable__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:11348:1: rule__ExternalServiceMock__Group__6__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__ExternalServiceMock__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11373:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:11374:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:11352:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:11353:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:11374:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:11375:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:11353:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:11354:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             before(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
             match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             after(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
 
             }
 
@@ -34623,26 +34392,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group__8__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group__6__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6__0"
-    // InternalTestgeneratorDSL.g:11385:1: rule__IntVariable__Group_6__0 : rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1 ;
-    public final void rule__IntVariable__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5__0"
+    // InternalTestgeneratorDSL.g:11364:1: rule__ExternalServiceMock__Group_5__0 : rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1 ;
+    public final void rule__ExternalServiceMock__Group_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11389:1: ( rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1 )
-            // InternalTestgeneratorDSL.g:11390:2: rule__IntVariable__Group_6__0__Impl rule__IntVariable__Group_6__1
+            // InternalTestgeneratorDSL.g:11368:1: ( rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1 )
+            // InternalTestgeneratorDSL.g:11369:2: rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1
             {
             pushFollow(FOLLOW_15);
-            rule__IntVariable__Group_6__0__Impl();
+            rule__ExternalServiceMock__Group_5__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group_6__1();
+            rule__ExternalServiceMock__Group_5__1();
 
             state._fsp--;
 
@@ -34661,35 +34430,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6__0"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5__0"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:11397:1: rule__IntVariable__Group_6__0__Impl : ( ( rule__IntVariable__ProposalsAssignment_6_0 ) ) ;
-    public final void rule__IntVariable__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5__0__Impl"
+    // InternalTestgeneratorDSL.g:11376:1: rule__ExternalServiceMock__Group_5__0__Impl : ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) ) ;
+    public final void rule__ExternalServiceMock__Group_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11401:1: ( ( ( rule__IntVariable__ProposalsAssignment_6_0 ) ) )
-            // InternalTestgeneratorDSL.g:11402:1: ( ( rule__IntVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:11380:1: ( ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) ) )
+            // InternalTestgeneratorDSL.g:11381:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) )
             {
-            // InternalTestgeneratorDSL.g:11402:1: ( ( rule__IntVariable__ProposalsAssignment_6_0 ) )
-            // InternalTestgeneratorDSL.g:11403:2: ( rule__IntVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:11381:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) )
+            // InternalTestgeneratorDSL.g:11382:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 )
             {
-             before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); 
-            // InternalTestgeneratorDSL.g:11404:2: ( rule__IntVariable__ProposalsAssignment_6_0 )
-            // InternalTestgeneratorDSL.g:11404:3: rule__IntVariable__ProposalsAssignment_6_0
+             before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); 
+            // InternalTestgeneratorDSL.g:11383:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 )
+            // InternalTestgeneratorDSL.g:11383:3: rule__ExternalServiceMock__MockingRulesAssignment_5_0
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__ProposalsAssignment_6_0();
+            rule__ExternalServiceMock__MockingRulesAssignment_5_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_0()); 
+             after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); 
 
             }
 
@@ -34708,21 +34477,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6__0__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5__0__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6__1"
-    // InternalTestgeneratorDSL.g:11412:1: rule__IntVariable__Group_6__1 : rule__IntVariable__Group_6__1__Impl ;
-    public final void rule__IntVariable__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5__1"
+    // InternalTestgeneratorDSL.g:11391:1: rule__ExternalServiceMock__Group_5__1 : rule__ExternalServiceMock__Group_5__1__Impl ;
+    public final void rule__ExternalServiceMock__Group_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11416:1: ( rule__IntVariable__Group_6__1__Impl )
-            // InternalTestgeneratorDSL.g:11417:2: rule__IntVariable__Group_6__1__Impl
+            // InternalTestgeneratorDSL.g:11395:1: ( rule__ExternalServiceMock__Group_5__1__Impl )
+            // InternalTestgeneratorDSL.g:11396:2: rule__ExternalServiceMock__Group_5__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group_6__1__Impl();
+            rule__ExternalServiceMock__Group_5__1__Impl();
 
             state._fsp--;
 
@@ -34741,40 +34510,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6__1"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5__1"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:11423:1: rule__IntVariable__Group_6__1__Impl : ( ( rule__IntVariable__Group_6_1__0 )* ) ;
-    public final void rule__IntVariable__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5__1__Impl"
+    // InternalTestgeneratorDSL.g:11402:1: rule__ExternalServiceMock__Group_5__1__Impl : ( ( rule__ExternalServiceMock__Group_5_1__0 )* ) ;
+    public final void rule__ExternalServiceMock__Group_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11427:1: ( ( ( rule__IntVariable__Group_6_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:11428:1: ( ( rule__IntVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:11406:1: ( ( ( rule__ExternalServiceMock__Group_5_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:11407:1: ( ( rule__ExternalServiceMock__Group_5_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:11428:1: ( ( rule__IntVariable__Group_6_1__0 )* )
-            // InternalTestgeneratorDSL.g:11429:2: ( rule__IntVariable__Group_6_1__0 )*
+            // InternalTestgeneratorDSL.g:11407:1: ( ( rule__ExternalServiceMock__Group_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:11408:2: ( rule__ExternalServiceMock__Group_5_1__0 )*
             {
-             before(grammarAccess.getIntVariableAccess().getGroup_6_1()); 
-            // InternalTestgeneratorDSL.g:11430:2: ( rule__IntVariable__Group_6_1__0 )*
-            loop85:
+             before(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); 
+            // InternalTestgeneratorDSL.g:11409:2: ( rule__ExternalServiceMock__Group_5_1__0 )*
+            loop67:
             do {
-                int alt85=2;
-                int LA85_0 = input.LA(1);
+                int alt67=2;
+                int LA67_0 = input.LA(1);
 
-                if ( (LA85_0==RULE_SEPARATOR) ) {
-                    alt85=1;
+                if ( (LA67_0==RULE_SEPARATOR) ) {
+                    alt67=1;
                 }
 
 
-                switch (alt85) {
+                switch (alt67) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:11430:3: rule__IntVariable__Group_6_1__0
+            	    // InternalTestgeneratorDSL.g:11409:3: rule__ExternalServiceMock__Group_5_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__IntVariable__Group_6_1__0();
+            	    rule__ExternalServiceMock__Group_5_1__0();
 
             	    state._fsp--;
 
@@ -34783,11 +34552,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop85;
+            	    break loop67;
                 }
             } while (true);
 
-             after(grammarAccess.getIntVariableAccess().getGroup_6_1()); 
+             after(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); 
 
             }
 
@@ -34806,26 +34575,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6__1__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5__1__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6_1__0"
-    // InternalTestgeneratorDSL.g:11439:1: rule__IntVariable__Group_6_1__0 : rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1 ;
-    public final void rule__IntVariable__Group_6_1__0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__0"
+    // InternalTestgeneratorDSL.g:11418:1: rule__ExternalServiceMock__Group_5_1__0 : rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1 ;
+    public final void rule__ExternalServiceMock__Group_5_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11443:1: ( rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1 )
-            // InternalTestgeneratorDSL.g:11444:2: rule__IntVariable__Group_6_1__0__Impl rule__IntVariable__Group_6_1__1
+            // InternalTestgeneratorDSL.g:11422:1: ( rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1 )
+            // InternalTestgeneratorDSL.g:11423:2: rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1
             {
-            pushFollow(FOLLOW_43);
-            rule__IntVariable__Group_6_1__0__Impl();
+            pushFollow(FOLLOW_5);
+            rule__ExternalServiceMock__Group_5_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group_6_1__1();
+            rule__ExternalServiceMock__Group_5_1__1();
 
             state._fsp--;
 
@@ -34844,25 +34613,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6_1__0"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__0"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6_1__0__Impl"
-    // InternalTestgeneratorDSL.g:11451:1: rule__IntVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__IntVariable__Group_6_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__0__Impl"
+    // InternalTestgeneratorDSL.g:11430:1: rule__ExternalServiceMock__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__ExternalServiceMock__Group_5_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11455:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:11456:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11434:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:11435:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:11456:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:11457:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:11435:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11436:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+             before(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+             after(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
 
             }
 
@@ -34881,21 +34650,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6_1__0__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__0__Impl"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6_1__1"
-    // InternalTestgeneratorDSL.g:11466:1: rule__IntVariable__Group_6_1__1 : rule__IntVariable__Group_6_1__1__Impl ;
-    public final void rule__IntVariable__Group_6_1__1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__1"
+    // InternalTestgeneratorDSL.g:11445:1: rule__ExternalServiceMock__Group_5_1__1 : rule__ExternalServiceMock__Group_5_1__1__Impl ;
+    public final void rule__ExternalServiceMock__Group_5_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11470:1: ( rule__IntVariable__Group_6_1__1__Impl )
-            // InternalTestgeneratorDSL.g:11471:2: rule__IntVariable__Group_6_1__1__Impl
+            // InternalTestgeneratorDSL.g:11449:1: ( rule__ExternalServiceMock__Group_5_1__1__Impl )
+            // InternalTestgeneratorDSL.g:11450:2: rule__ExternalServiceMock__Group_5_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__Group_6_1__1__Impl();
+            rule__ExternalServiceMock__Group_5_1__1__Impl();
 
             state._fsp--;
 
@@ -34914,35 +34683,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6_1__1"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__1"
 
 
-    // $ANTLR start "rule__IntVariable__Group_6_1__1__Impl"
-    // InternalTestgeneratorDSL.g:11477:1: rule__IntVariable__Group_6_1__1__Impl : ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) ) ;
-    public final void rule__IntVariable__Group_6_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__1__Impl"
+    // InternalTestgeneratorDSL.g:11456:1: rule__ExternalServiceMock__Group_5_1__1__Impl : ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) ) ;
+    public final void rule__ExternalServiceMock__Group_5_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11481:1: ( ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:11482:1: ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) )
+            // InternalTestgeneratorDSL.g:11460:1: ( ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:11461:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:11482:1: ( ( rule__IntVariable__ProposalsAssignment_6_1_1 ) )
-            // InternalTestgeneratorDSL.g:11483:2: ( rule__IntVariable__ProposalsAssignment_6_1_1 )
+            // InternalTestgeneratorDSL.g:11461:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:11462:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 )
             {
-             before(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); 
-            // InternalTestgeneratorDSL.g:11484:2: ( rule__IntVariable__ProposalsAssignment_6_1_1 )
-            // InternalTestgeneratorDSL.g:11484:3: rule__IntVariable__ProposalsAssignment_6_1_1
+             before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); 
+            // InternalTestgeneratorDSL.g:11463:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 )
+            // InternalTestgeneratorDSL.g:11463:3: rule__ExternalServiceMock__MockingRulesAssignment_5_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__IntVariable__ProposalsAssignment_6_1_1();
+            rule__ExternalServiceMock__MockingRulesAssignment_5_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getIntVariableAccess().getProposalsAssignment_6_1_1()); 
+             after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); 
 
             }
 
@@ -34961,26 +34730,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntVariable__Group_6_1__1__Impl"
+    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__1__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__0"
-    // InternalTestgeneratorDSL.g:11493:1: rule__BooleanVariable__Group__0 : rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1 ;
-    public final void rule__BooleanVariable__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__0"
+    // InternalTestgeneratorDSL.g:11472:1: rule__DelegateMock__Group__0 : rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1 ;
+    public final void rule__DelegateMock__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11497:1: ( rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1 )
-            // InternalTestgeneratorDSL.g:11498:2: rule__BooleanVariable__Group__0__Impl rule__BooleanVariable__Group__1
+            // InternalTestgeneratorDSL.g:11476:1: ( rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1 )
+            // InternalTestgeneratorDSL.g:11477:2: rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1
             {
             pushFollow(FOLLOW_4);
-            rule__BooleanVariable__Group__0__Impl();
+            rule__DelegateMock__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__1();
+            rule__DelegateMock__Group__1();
 
             state._fsp--;
 
@@ -34999,25 +34768,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__0"
+    // $ANTLR end "rule__DelegateMock__Group__0"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:11505:1: rule__BooleanVariable__Group__0__Impl : ( 'Boolean' ) ;
-    public final void rule__BooleanVariable__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:11484:1: rule__DelegateMock__Group__0__Impl : ( 'DelegateMock' ) ;
+    public final void rule__DelegateMock__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11509:1: ( ( 'Boolean' ) )
-            // InternalTestgeneratorDSL.g:11510:1: ( 'Boolean' )
+            // InternalTestgeneratorDSL.g:11488:1: ( ( 'DelegateMock' ) )
+            // InternalTestgeneratorDSL.g:11489:1: ( 'DelegateMock' )
             {
-            // InternalTestgeneratorDSL.g:11510:1: ( 'Boolean' )
-            // InternalTestgeneratorDSL.g:11511:2: 'Boolean'
+            // InternalTestgeneratorDSL.g:11489:1: ( 'DelegateMock' )
+            // InternalTestgeneratorDSL.g:11490:2: 'DelegateMock'
             {
-             before(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); 
-            match(input,59,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0()); 
+             before(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); 
+            match(input,80,FOLLOW_2); 
+             after(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); 
 
             }
 
@@ -35036,26 +34805,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__0__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__0__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__1"
-    // InternalTestgeneratorDSL.g:11520:1: rule__BooleanVariable__Group__1 : rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2 ;
-    public final void rule__BooleanVariable__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__1"
+    // InternalTestgeneratorDSL.g:11499:1: rule__DelegateMock__Group__1 : rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2 ;
+    public final void rule__DelegateMock__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11524:1: ( rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2 )
-            // InternalTestgeneratorDSL.g:11525:2: rule__BooleanVariable__Group__1__Impl rule__BooleanVariable__Group__2
+            // InternalTestgeneratorDSL.g:11503:1: ( rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2 )
+            // InternalTestgeneratorDSL.g:11504:2: rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2
             {
-            pushFollow(FOLLOW_5);
-            rule__BooleanVariable__Group__1__Impl();
+            pushFollow(FOLLOW_52);
+            rule__DelegateMock__Group__1__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__2();
+            rule__DelegateMock__Group__2();
 
             state._fsp--;
 
@@ -35074,35 +34843,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__1"
+    // $ANTLR end "rule__DelegateMock__Group__1"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:11532:1: rule__BooleanVariable__Group__1__Impl : ( ( rule__BooleanVariable__NameAssignment_1 ) ) ;
-    public final void rule__BooleanVariable__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:11511:1: rule__DelegateMock__Group__1__Impl : ( ( rule__DelegateMock__NameAssignment_1 ) ) ;
+    public final void rule__DelegateMock__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11536:1: ( ( ( rule__BooleanVariable__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:11537:1: ( ( rule__BooleanVariable__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:11515:1: ( ( ( rule__DelegateMock__NameAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:11516:1: ( ( rule__DelegateMock__NameAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:11537:1: ( ( rule__BooleanVariable__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:11538:2: ( rule__BooleanVariable__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:11516:1: ( ( rule__DelegateMock__NameAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:11517:2: ( rule__DelegateMock__NameAssignment_1 )
             {
-             before(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:11539:2: ( rule__BooleanVariable__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:11539:3: rule__BooleanVariable__NameAssignment_1
+             before(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); 
+            // InternalTestgeneratorDSL.g:11518:2: ( rule__DelegateMock__NameAssignment_1 )
+            // InternalTestgeneratorDSL.g:11518:3: rule__DelegateMock__NameAssignment_1
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__NameAssignment_1();
+            rule__DelegateMock__NameAssignment_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBooleanVariableAccess().getNameAssignment_1()); 
+             after(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); 
 
             }
 
@@ -35121,26 +34890,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__1__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__1__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__2"
-    // InternalTestgeneratorDSL.g:11547:1: rule__BooleanVariable__Group__2 : rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3 ;
-    public final void rule__BooleanVariable__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__2"
+    // InternalTestgeneratorDSL.g:11526:1: rule__DelegateMock__Group__2 : rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3 ;
+    public final void rule__DelegateMock__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11551:1: ( rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3 )
-            // InternalTestgeneratorDSL.g:11552:2: rule__BooleanVariable__Group__2__Impl rule__BooleanVariable__Group__3
+            // InternalTestgeneratorDSL.g:11530:1: ( rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3 )
+            // InternalTestgeneratorDSL.g:11531:2: rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3
             {
-            pushFollow(FOLLOW_41);
-            rule__BooleanVariable__Group__2__Impl();
+            pushFollow(FOLLOW_4);
+            rule__DelegateMock__Group__2__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__3();
+            rule__DelegateMock__Group__3();
 
             state._fsp--;
 
@@ -35159,25 +34928,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__2"
+    // $ANTLR end "rule__DelegateMock__Group__2"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:11559:1: rule__BooleanVariable__Group__2__Impl : ( 'with' ) ;
-    public final void rule__BooleanVariable__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:11538:1: rule__DelegateMock__Group__2__Impl : ( 'for' ) ;
+    public final void rule__DelegateMock__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11563:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:11564:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:11542:1: ( ( 'for' ) )
+            // InternalTestgeneratorDSL.g:11543:1: ( 'for' )
             {
-            // InternalTestgeneratorDSL.g:11564:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:11565:2: 'with'
+            // InternalTestgeneratorDSL.g:11543:1: ( 'for' )
+            // InternalTestgeneratorDSL.g:11544:2: 'for'
             {
-             before(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getWithKeyword_2()); 
+             before(grammarAccess.getDelegateMockAccess().getForKeyword_2()); 
+            match(input,68,FOLLOW_2); 
+             after(grammarAccess.getDelegateMockAccess().getForKeyword_2()); 
 
             }
 
@@ -35196,26 +34965,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__2__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__2__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__3"
-    // InternalTestgeneratorDSL.g:11574:1: rule__BooleanVariable__Group__3 : rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4 ;
-    public final void rule__BooleanVariable__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__3"
+    // InternalTestgeneratorDSL.g:11553:1: rule__DelegateMock__Group__3 : rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4 ;
+    public final void rule__DelegateMock__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11578:1: ( rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4 )
-            // InternalTestgeneratorDSL.g:11579:2: rule__BooleanVariable__Group__3__Impl rule__BooleanVariable__Group__4
+            // InternalTestgeneratorDSL.g:11557:1: ( rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4 )
+            // InternalTestgeneratorDSL.g:11558:2: rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4
             {
-            pushFollow(FOLLOW_12);
-            rule__BooleanVariable__Group__3__Impl();
+            pushFollow(FOLLOW_5);
+            rule__DelegateMock__Group__3__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__4();
+            rule__DelegateMock__Group__4();
 
             state._fsp--;
 
@@ -35234,25 +35003,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__3"
+    // $ANTLR end "rule__DelegateMock__Group__3"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:11586:1: rule__BooleanVariable__Group__3__Impl : ( 'proposals' ) ;
-    public final void rule__BooleanVariable__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:11565:1: rule__DelegateMock__Group__3__Impl : ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) ) ;
+    public final void rule__DelegateMock__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11590:1: ( ( 'proposals' ) )
-            // InternalTestgeneratorDSL.g:11591:1: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:11569:1: ( ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) ) )
+            // InternalTestgeneratorDSL.g:11570:1: ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) )
             {
-            // InternalTestgeneratorDSL.g:11591:1: ( 'proposals' )
-            // InternalTestgeneratorDSL.g:11592:2: 'proposals'
+            // InternalTestgeneratorDSL.g:11570:1: ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) )
+            // InternalTestgeneratorDSL.g:11571:2: ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 )
             {
-             before(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); 
-            match(input,57,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3()); 
+             before(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); 
+            // InternalTestgeneratorDSL.g:11572:2: ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 )
+            // InternalTestgeneratorDSL.g:11572:3: rule__DelegateMock__ServiceTaskReferenceAssignment_3
+            {
+            pushFollow(FOLLOW_2);
+            rule__DelegateMock__ServiceTaskReferenceAssignment_3();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); 
 
             }
 
@@ -35271,26 +35050,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__3__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__3__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__4"
-    // InternalTestgeneratorDSL.g:11601:1: rule__BooleanVariable__Group__4 : rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5 ;
-    public final void rule__BooleanVariable__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__4"
+    // InternalTestgeneratorDSL.g:11580:1: rule__DelegateMock__Group__4 : rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5 ;
+    public final void rule__DelegateMock__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11605:1: ( rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5 )
-            // InternalTestgeneratorDSL.g:11606:2: rule__BooleanVariable__Group__4__Impl rule__BooleanVariable__Group__5
+            // InternalTestgeneratorDSL.g:11584:1: ( rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5 )
+            // InternalTestgeneratorDSL.g:11585:2: rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5
             {
-            pushFollow(FOLLOW_13);
-            rule__BooleanVariable__Group__4__Impl();
+            pushFollow(FOLLOW_30);
+            rule__DelegateMock__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__5();
+            rule__DelegateMock__Group__5();
 
             state._fsp--;
 
@@ -35309,25 +35088,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__4"
+    // $ANTLR end "rule__DelegateMock__Group__4"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:11613:1: rule__BooleanVariable__Group__4__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__BooleanVariable__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:11592:1: rule__DelegateMock__Group__4__Impl : ( 'with' ) ;
+    public final void rule__DelegateMock__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11617:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:11618:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:11596:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:11597:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:11618:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:11619:2: RULE_ASSOCIATION
+            // InternalTestgeneratorDSL.g:11597:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:11598:2: 'with'
             {
-             before(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getASSOCIATIONTerminalRuleCall_4()); 
+             before(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); 
 
             }
 
@@ -35346,26 +35125,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__4__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__4__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__5"
-    // InternalTestgeneratorDSL.g:11628:1: rule__BooleanVariable__Group__5 : rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6 ;
-    public final void rule__BooleanVariable__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__5"
+    // InternalTestgeneratorDSL.g:11607:1: rule__DelegateMock__Group__5 : rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6 ;
+    public final void rule__DelegateMock__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11632:1: ( rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6 )
-            // InternalTestgeneratorDSL.g:11633:2: rule__BooleanVariable__Group__5__Impl rule__BooleanVariable__Group__6
+            // InternalTestgeneratorDSL.g:11611:1: ( rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6 )
+            // InternalTestgeneratorDSL.g:11612:2: rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6
             {
-            pushFollow(FOLLOW_44);
-            rule__BooleanVariable__Group__5__Impl();
+            pushFollow(FOLLOW_7);
+            rule__DelegateMock__Group__5__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__6();
+            rule__DelegateMock__Group__6();
 
             state._fsp--;
 
@@ -35384,25 +35163,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__5"
+    // $ANTLR end "rule__DelegateMock__Group__5"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:11640:1: rule__BooleanVariable__Group__5__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__BooleanVariable__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:11619:1: rule__DelegateMock__Group__5__Impl : ( 'delegate' ) ;
+    public final void rule__DelegateMock__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11644:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:11645:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:11623:1: ( ( 'delegate' ) )
+            // InternalTestgeneratorDSL.g:11624:1: ( 'delegate' )
             {
-            // InternalTestgeneratorDSL.g:11645:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:11646:2: RULE_LIST_OPEN
+            // InternalTestgeneratorDSL.g:11624:1: ( 'delegate' )
+            // InternalTestgeneratorDSL.g:11625:2: 'delegate'
             {
-             before(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5()); 
+             before(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); 
+            match(input,45,FOLLOW_2); 
+             after(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); 
 
             }
 
@@ -35421,26 +35200,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__5__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__5__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__6"
-    // InternalTestgeneratorDSL.g:11655:1: rule__BooleanVariable__Group__6 : rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7 ;
-    public final void rule__BooleanVariable__Group__6() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__6"
+    // InternalTestgeneratorDSL.g:11634:1: rule__DelegateMock__Group__6 : rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7 ;
+    public final void rule__DelegateMock__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11659:1: ( rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7 )
-            // InternalTestgeneratorDSL.g:11660:2: rule__BooleanVariable__Group__6__Impl rule__BooleanVariable__Group__7
+            // InternalTestgeneratorDSL.g:11638:1: ( rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7 )
+            // InternalTestgeneratorDSL.g:11639:2: rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7
             {
-            pushFollow(FOLLOW_44);
-            rule__BooleanVariable__Group__6__Impl();
+            pushFollow(FOLLOW_10);
+            rule__DelegateMock__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__7();
+            rule__DelegateMock__Group__7();
 
             state._fsp--;
 
@@ -35459,46 +35238,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__6"
+    // $ANTLR end "rule__DelegateMock__Group__6"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:11667:1: rule__BooleanVariable__Group__6__Impl : ( ( rule__BooleanVariable__Group_6__0 )? ) ;
-    public final void rule__BooleanVariable__Group__6__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:11646:1: rule__DelegateMock__Group__6__Impl : ( ( rule__DelegateMock__DelegateClassAssignment_6 ) ) ;
+    public final void rule__DelegateMock__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11671:1: ( ( ( rule__BooleanVariable__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:11672:1: ( ( rule__BooleanVariable__Group_6__0 )? )
+            // InternalTestgeneratorDSL.g:11650:1: ( ( ( rule__DelegateMock__DelegateClassAssignment_6 ) ) )
+            // InternalTestgeneratorDSL.g:11651:1: ( ( rule__DelegateMock__DelegateClassAssignment_6 ) )
             {
-            // InternalTestgeneratorDSL.g:11672:1: ( ( rule__BooleanVariable__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:11673:2: ( rule__BooleanVariable__Group_6__0 )?
+            // InternalTestgeneratorDSL.g:11651:1: ( ( rule__DelegateMock__DelegateClassAssignment_6 ) )
+            // InternalTestgeneratorDSL.g:11652:2: ( rule__DelegateMock__DelegateClassAssignment_6 )
             {
-             before(grammarAccess.getBooleanVariableAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:11674:2: ( rule__BooleanVariable__Group_6__0 )?
-            int alt86=2;
-            int LA86_0 = input.LA(1);
-
-            if ( ((LA86_0>=16 && LA86_0<=17)) ) {
-                alt86=1;
-            }
-            switch (alt86) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:11674:3: rule__BooleanVariable__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__BooleanVariable__Group_6__0();
-
-                    state._fsp--;
+             before(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); 
+            // InternalTestgeneratorDSL.g:11653:2: ( rule__DelegateMock__DelegateClassAssignment_6 )
+            // InternalTestgeneratorDSL.g:11653:3: rule__DelegateMock__DelegateClassAssignment_6
+            {
+            pushFollow(FOLLOW_2);
+            rule__DelegateMock__DelegateClassAssignment_6();
 
+            state._fsp--;
 
-                    }
-                    break;
 
             }
 
-             after(grammarAccess.getBooleanVariableAccess().getGroup_6()); 
+             after(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); 
 
             }
 
@@ -35517,26 +35285,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__6__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__6__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__7"
-    // InternalTestgeneratorDSL.g:11682:1: rule__BooleanVariable__Group__7 : rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8 ;
-    public final void rule__BooleanVariable__Group__7() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__7"
+    // InternalTestgeneratorDSL.g:11661:1: rule__DelegateMock__Group__7 : rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8 ;
+    public final void rule__DelegateMock__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11686:1: ( rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8 )
-            // InternalTestgeneratorDSL.g:11687:2: rule__BooleanVariable__Group__7__Impl rule__BooleanVariable__Group__8
+            // InternalTestgeneratorDSL.g:11665:1: ( rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8 )
+            // InternalTestgeneratorDSL.g:11666:2: rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8
             {
-            pushFollow(FOLLOW_24);
-            rule__BooleanVariable__Group__7__Impl();
+            pushFollow(FOLLOW_10);
+            rule__DelegateMock__Group__7__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__8();
+            rule__DelegateMock__Group__8();
 
             state._fsp--;
 
@@ -35555,25 +35323,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__7"
+    // $ANTLR end "rule__DelegateMock__Group__7"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:11694:1: rule__BooleanVariable__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__BooleanVariable__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:11673:1: rule__DelegateMock__Group__7__Impl : ( ( rule__DelegateMock__Group_7__0 )? ) ;
+    public final void rule__DelegateMock__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11698:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:11699:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:11677:1: ( ( ( rule__DelegateMock__Group_7__0 )? ) )
+            // InternalTestgeneratorDSL.g:11678:1: ( ( rule__DelegateMock__Group_7__0 )? )
             {
-            // InternalTestgeneratorDSL.g:11699:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:11700:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:11678:1: ( ( rule__DelegateMock__Group_7__0 )? )
+            // InternalTestgeneratorDSL.g:11679:2: ( rule__DelegateMock__Group_7__0 )?
             {
-             before(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
+             before(grammarAccess.getDelegateMockAccess().getGroup_7()); 
+            // InternalTestgeneratorDSL.g:11680:2: ( rule__DelegateMock__Group_7__0 )?
+            int alt68=2;
+            int LA68_0 = input.LA(1);
+
+            if ( (LA68_0==29) ) {
+                alt68=1;
+            }
+            switch (alt68) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:11680:3: rule__DelegateMock__Group_7__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__DelegateMock__Group_7__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getDelegateMockAccess().getGroup_7()); 
 
             }
 
@@ -35592,21 +35381,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__7__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__7__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__8"
-    // InternalTestgeneratorDSL.g:11709:1: rule__BooleanVariable__Group__8 : rule__BooleanVariable__Group__8__Impl ;
-    public final void rule__BooleanVariable__Group__8() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__8"
+    // InternalTestgeneratorDSL.g:11688:1: rule__DelegateMock__Group__8 : rule__DelegateMock__Group__8__Impl ;
+    public final void rule__DelegateMock__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11713:1: ( rule__BooleanVariable__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:11714:2: rule__BooleanVariable__Group__8__Impl
+            // InternalTestgeneratorDSL.g:11692:1: ( rule__DelegateMock__Group__8__Impl )
+            // InternalTestgeneratorDSL.g:11693:2: rule__DelegateMock__Group__8__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group__8__Impl();
+            rule__DelegateMock__Group__8__Impl();
 
             state._fsp--;
 
@@ -35625,25 +35414,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__8"
+    // $ANTLR end "rule__DelegateMock__Group__8"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:11720:1: rule__BooleanVariable__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__BooleanVariable__Group__8__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:11699:1: rule__DelegateMock__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
+    public final void rule__DelegateMock__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11724:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:11725:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:11703:1: ( ( RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:11704:1: ( RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:11725:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:11726:2: RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:11704:1: ( RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:11705:2: RULE_DECLARATION_FINISHED
             {
-             before(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             before(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
             match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
+             after(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
 
             }
 
@@ -35662,26 +35451,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group__8__Impl"
+    // $ANTLR end "rule__DelegateMock__Group__8__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6__0"
-    // InternalTestgeneratorDSL.g:11736:1: rule__BooleanVariable__Group_6__0 : rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1 ;
-    public final void rule__BooleanVariable__Group_6__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7__0"
+    // InternalTestgeneratorDSL.g:11715:1: rule__DelegateMock__Group_7__0 : rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1 ;
+    public final void rule__DelegateMock__Group_7__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11740:1: ( rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1 )
-            // InternalTestgeneratorDSL.g:11741:2: rule__BooleanVariable__Group_6__0__Impl rule__BooleanVariable__Group_6__1
+            // InternalTestgeneratorDSL.g:11719:1: ( rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1 )
+            // InternalTestgeneratorDSL.g:11720:2: rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1
             {
             pushFollow(FOLLOW_15);
-            rule__BooleanVariable__Group_6__0__Impl();
+            rule__DelegateMock__Group_7__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group_6__1();
+            rule__DelegateMock__Group_7__1();
 
             state._fsp--;
 
@@ -35700,35 +35489,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6__0"
+    // $ANTLR end "rule__DelegateMock__Group_7__0"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:11748:1: rule__BooleanVariable__Group_6__0__Impl : ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) ) ;
-    public final void rule__BooleanVariable__Group_6__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7__0__Impl"
+    // InternalTestgeneratorDSL.g:11727:1: rule__DelegateMock__Group_7__0__Impl : ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) ) ;
+    public final void rule__DelegateMock__Group_7__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11752:1: ( ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) ) )
-            // InternalTestgeneratorDSL.g:11753:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) )
+            // InternalTestgeneratorDSL.g:11731:1: ( ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) ) )
+            // InternalTestgeneratorDSL.g:11732:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) )
             {
-            // InternalTestgeneratorDSL.g:11753:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_0 ) )
-            // InternalTestgeneratorDSL.g:11754:2: ( rule__BooleanVariable__ProposalsAssignment_6_0 )
+            // InternalTestgeneratorDSL.g:11732:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) )
+            // InternalTestgeneratorDSL.g:11733:2: ( rule__DelegateMock__ManualMocksAssignment_7_0 )
             {
-             before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); 
-            // InternalTestgeneratorDSL.g:11755:2: ( rule__BooleanVariable__ProposalsAssignment_6_0 )
-            // InternalTestgeneratorDSL.g:11755:3: rule__BooleanVariable__ProposalsAssignment_6_0
+             before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); 
+            // InternalTestgeneratorDSL.g:11734:2: ( rule__DelegateMock__ManualMocksAssignment_7_0 )
+            // InternalTestgeneratorDSL.g:11734:3: rule__DelegateMock__ManualMocksAssignment_7_0
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__ProposalsAssignment_6_0();
+            rule__DelegateMock__ManualMocksAssignment_7_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_0()); 
+             after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); 
 
             }
 
@@ -35747,21 +35536,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6__0__Impl"
+    // $ANTLR end "rule__DelegateMock__Group_7__0__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6__1"
-    // InternalTestgeneratorDSL.g:11763:1: rule__BooleanVariable__Group_6__1 : rule__BooleanVariable__Group_6__1__Impl ;
-    public final void rule__BooleanVariable__Group_6__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7__1"
+    // InternalTestgeneratorDSL.g:11742:1: rule__DelegateMock__Group_7__1 : rule__DelegateMock__Group_7__1__Impl ;
+    public final void rule__DelegateMock__Group_7__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11767:1: ( rule__BooleanVariable__Group_6__1__Impl )
-            // InternalTestgeneratorDSL.g:11768:2: rule__BooleanVariable__Group_6__1__Impl
+            // InternalTestgeneratorDSL.g:11746:1: ( rule__DelegateMock__Group_7__1__Impl )
+            // InternalTestgeneratorDSL.g:11747:2: rule__DelegateMock__Group_7__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group_6__1__Impl();
+            rule__DelegateMock__Group_7__1__Impl();
 
             state._fsp--;
 
@@ -35780,40 +35569,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6__1"
+    // $ANTLR end "rule__DelegateMock__Group_7__1"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:11774:1: rule__BooleanVariable__Group_6__1__Impl : ( ( rule__BooleanVariable__Group_6_1__0 )* ) ;
-    public final void rule__BooleanVariable__Group_6__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7__1__Impl"
+    // InternalTestgeneratorDSL.g:11753:1: rule__DelegateMock__Group_7__1__Impl : ( ( rule__DelegateMock__Group_7_1__0 )* ) ;
+    public final void rule__DelegateMock__Group_7__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11778:1: ( ( ( rule__BooleanVariable__Group_6_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:11779:1: ( ( rule__BooleanVariable__Group_6_1__0 )* )
+            // InternalTestgeneratorDSL.g:11757:1: ( ( ( rule__DelegateMock__Group_7_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:11758:1: ( ( rule__DelegateMock__Group_7_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:11779:1: ( ( rule__BooleanVariable__Group_6_1__0 )* )
-            // InternalTestgeneratorDSL.g:11780:2: ( rule__BooleanVariable__Group_6_1__0 )*
+            // InternalTestgeneratorDSL.g:11758:1: ( ( rule__DelegateMock__Group_7_1__0 )* )
+            // InternalTestgeneratorDSL.g:11759:2: ( rule__DelegateMock__Group_7_1__0 )*
             {
-             before(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); 
-            // InternalTestgeneratorDSL.g:11781:2: ( rule__BooleanVariable__Group_6_1__0 )*
-            loop87:
+             before(grammarAccess.getDelegateMockAccess().getGroup_7_1()); 
+            // InternalTestgeneratorDSL.g:11760:2: ( rule__DelegateMock__Group_7_1__0 )*
+            loop69:
             do {
-                int alt87=2;
-                int LA87_0 = input.LA(1);
+                int alt69=2;
+                int LA69_0 = input.LA(1);
 
-                if ( (LA87_0==RULE_SEPARATOR) ) {
-                    alt87=1;
+                if ( (LA69_0==RULE_SEPARATOR) ) {
+                    alt69=1;
                 }
 
 
-                switch (alt87) {
+                switch (alt69) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:11781:3: rule__BooleanVariable__Group_6_1__0
+            	    // InternalTestgeneratorDSL.g:11760:3: rule__DelegateMock__Group_7_1__0
             	    {
             	    pushFollow(FOLLOW_16);
-            	    rule__BooleanVariable__Group_6_1__0();
+            	    rule__DelegateMock__Group_7_1__0();
 
             	    state._fsp--;
 
@@ -35822,11 +35611,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
             	    break;
 
             	default :
-            	    break loop87;
+            	    break loop69;
                 }
             } while (true);
 
-             after(grammarAccess.getBooleanVariableAccess().getGroup_6_1()); 
+             after(grammarAccess.getDelegateMockAccess().getGroup_7_1()); 
 
             }
 
@@ -35845,26 +35634,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6__1__Impl"
+    // $ANTLR end "rule__DelegateMock__Group_7__1__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6_1__0"
-    // InternalTestgeneratorDSL.g:11790:1: rule__BooleanVariable__Group_6_1__0 : rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1 ;
-    public final void rule__BooleanVariable__Group_6_1__0() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7_1__0"
+    // InternalTestgeneratorDSL.g:11769:1: rule__DelegateMock__Group_7_1__0 : rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1 ;
+    public final void rule__DelegateMock__Group_7_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11794:1: ( rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1 )
-            // InternalTestgeneratorDSL.g:11795:2: rule__BooleanVariable__Group_6_1__0__Impl rule__BooleanVariable__Group_6_1__1
+            // InternalTestgeneratorDSL.g:11773:1: ( rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1 )
+            // InternalTestgeneratorDSL.g:11774:2: rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1
             {
-            pushFollow(FOLLOW_45);
-            rule__BooleanVariable__Group_6_1__0__Impl();
+            pushFollow(FOLLOW_5);
+            rule__DelegateMock__Group_7_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group_6_1__1();
+            rule__DelegateMock__Group_7_1__1();
 
             state._fsp--;
 
@@ -35883,25 +35672,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6_1__0"
+    // $ANTLR end "rule__DelegateMock__Group_7_1__0"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6_1__0__Impl"
-    // InternalTestgeneratorDSL.g:11802:1: rule__BooleanVariable__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__BooleanVariable__Group_6_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7_1__0__Impl"
+    // InternalTestgeneratorDSL.g:11781:1: rule__DelegateMock__Group_7_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__DelegateMock__Group_7_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11806:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:11807:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11785:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:11786:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:11807:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:11808:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:11786:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11787:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+             before(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); 
             match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
+             after(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); 
 
             }
 
@@ -35920,21 +35709,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6_1__0__Impl"
+    // $ANTLR end "rule__DelegateMock__Group_7_1__0__Impl"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6_1__1"
-    // InternalTestgeneratorDSL.g:11817:1: rule__BooleanVariable__Group_6_1__1 : rule__BooleanVariable__Group_6_1__1__Impl ;
-    public final void rule__BooleanVariable__Group_6_1__1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7_1__1"
+    // InternalTestgeneratorDSL.g:11796:1: rule__DelegateMock__Group_7_1__1 : rule__DelegateMock__Group_7_1__1__Impl ;
+    public final void rule__DelegateMock__Group_7_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:11821:1: ( rule__BooleanVariable__Group_6_1__1__Impl )
-            // InternalTestgeneratorDSL.g:11822:2: rule__BooleanVariable__Group_6_1__1__Impl
+            // InternalTestgeneratorDSL.g:11800:1: ( rule__DelegateMock__Group_7_1__1__Impl )
+            // InternalTestgeneratorDSL.g:11801:2: rule__DelegateMock__Group_7_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanVariable__Group_6_1__1__Impl();
+            rule__DelegateMock__Group_7_1__1__Impl();
 
             state._fsp--;
 
@@ -35953,13183 +35742,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanVariable__Group_6_1__1"
+    // $ANTLR end "rule__DelegateMock__Group_7_1__1"
 
 
-    // $ANTLR start "rule__BooleanVariable__Group_6_1__1__Impl"
-    // InternalTestgeneratorDSL.g:11828:1: rule__BooleanVariable__Group_6_1__1__Impl : ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) ) ;
-    public final void rule__BooleanVariable__Group_6_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11832:1: ( ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:11833:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:11833:1: ( ( rule__BooleanVariable__ProposalsAssignment_6_1_1 ) )
-            // InternalTestgeneratorDSL.g:11834:2: ( rule__BooleanVariable__ProposalsAssignment_6_1_1 )
-            {
-             before(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); 
-            // InternalTestgeneratorDSL.g:11835:2: ( rule__BooleanVariable__ProposalsAssignment_6_1_1 )
-            // InternalTestgeneratorDSL.g:11835:3: rule__BooleanVariable__ProposalsAssignment_6_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariable__ProposalsAssignment_6_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableAccess().getProposalsAssignment_6_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariable__Group_6_1__1__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__0"
-    // InternalTestgeneratorDSL.g:11844:1: rule__Loop__Group__0 : rule__Loop__Group__0__Impl rule__Loop__Group__1 ;
-    public final void rule__Loop__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11848:1: ( rule__Loop__Group__0__Impl rule__Loop__Group__1 )
-            // InternalTestgeneratorDSL.g:11849:2: rule__Loop__Group__0__Impl rule__Loop__Group__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Loop__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__0"
-
-
-    // $ANTLR start "rule__Loop__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:11856:1: rule__Loop__Group__0__Impl : ( 'Loop' ) ;
-    public final void rule__Loop__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11860:1: ( ( 'Loop' ) )
-            // InternalTestgeneratorDSL.g:11861:1: ( 'Loop' )
-            {
-            // InternalTestgeneratorDSL.g:11861:1: ( 'Loop' )
-            // InternalTestgeneratorDSL.g:11862:2: 'Loop'
-            {
-             before(grammarAccess.getLoopAccess().getLoopKeyword_0()); 
-            match(input,60,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getLoopKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__0__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__1"
-    // InternalTestgeneratorDSL.g:11871:1: rule__Loop__Group__1 : rule__Loop__Group__1__Impl rule__Loop__Group__2 ;
-    public final void rule__Loop__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11875:1: ( rule__Loop__Group__1__Impl rule__Loop__Group__2 )
-            // InternalTestgeneratorDSL.g:11876:2: rule__Loop__Group__1__Impl rule__Loop__Group__2
-            {
-            pushFollow(FOLLOW_46);
-            rule__Loop__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__1"
-
-
-    // $ANTLR start "rule__Loop__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:11883:1: rule__Loop__Group__1__Impl : ( ( rule__Loop__NameAssignment_1 ) ) ;
-    public final void rule__Loop__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11887:1: ( ( ( rule__Loop__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:11888:1: ( ( rule__Loop__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:11888:1: ( ( rule__Loop__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:11889:2: ( rule__Loop__NameAssignment_1 )
-            {
-             before(grammarAccess.getLoopAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:11890:2: ( rule__Loop__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:11890:3: rule__Loop__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getNameAssignment_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__1__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__2"
-    // InternalTestgeneratorDSL.g:11898:1: rule__Loop__Group__2 : rule__Loop__Group__2__Impl rule__Loop__Group__3 ;
-    public final void rule__Loop__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11902:1: ( rule__Loop__Group__2__Impl rule__Loop__Group__3 )
-            // InternalTestgeneratorDSL.g:11903:2: rule__Loop__Group__2__Impl rule__Loop__Group__3
-            {
-            pushFollow(FOLLOW_5);
-            rule__Loop__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__2"
-
-
-    // $ANTLR start "rule__Loop__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:11910:1: rule__Loop__Group__2__Impl : ( 'starts' ) ;
-    public final void rule__Loop__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11914:1: ( ( 'starts' ) )
-            // InternalTestgeneratorDSL.g:11915:1: ( 'starts' )
-            {
-            // InternalTestgeneratorDSL.g:11915:1: ( 'starts' )
-            // InternalTestgeneratorDSL.g:11916:2: 'starts'
-            {
-             before(grammarAccess.getLoopAccess().getStartsKeyword_2()); 
-            match(input,61,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getStartsKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__2__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__3"
-    // InternalTestgeneratorDSL.g:11925:1: rule__Loop__Group__3 : rule__Loop__Group__3__Impl rule__Loop__Group__4 ;
-    public final void rule__Loop__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11929:1: ( rule__Loop__Group__3__Impl rule__Loop__Group__4 )
-            // InternalTestgeneratorDSL.g:11930:2: rule__Loop__Group__3__Impl rule__Loop__Group__4
-            {
-            pushFollow(FOLLOW_7);
-            rule__Loop__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__3"
-
-
-    // $ANTLR start "rule__Loop__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:11937:1: rule__Loop__Group__3__Impl : ( 'with' ) ;
-    public final void rule__Loop__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11941:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:11942:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:11942:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:11943:2: 'with'
-            {
-             before(grammarAccess.getLoopAccess().getWithKeyword_3()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getWithKeyword_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__3__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__4"
-    // InternalTestgeneratorDSL.g:11952:1: rule__Loop__Group__4 : rule__Loop__Group__4__Impl rule__Loop__Group__5 ;
-    public final void rule__Loop__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11956:1: ( rule__Loop__Group__4__Impl rule__Loop__Group__5 )
-            // InternalTestgeneratorDSL.g:11957:2: rule__Loop__Group__4__Impl rule__Loop__Group__5
-            {
-            pushFollow(FOLLOW_47);
-            rule__Loop__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__4"
-
-
-    // $ANTLR start "rule__Loop__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:11964:1: rule__Loop__Group__4__Impl : ( ( rule__Loop__StartAssignment_4 ) ) ;
-    public final void rule__Loop__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11968:1: ( ( ( rule__Loop__StartAssignment_4 ) ) )
-            // InternalTestgeneratorDSL.g:11969:1: ( ( rule__Loop__StartAssignment_4 ) )
-            {
-            // InternalTestgeneratorDSL.g:11969:1: ( ( rule__Loop__StartAssignment_4 ) )
-            // InternalTestgeneratorDSL.g:11970:2: ( rule__Loop__StartAssignment_4 )
-            {
-             before(grammarAccess.getLoopAccess().getStartAssignment_4()); 
-            // InternalTestgeneratorDSL.g:11971:2: ( rule__Loop__StartAssignment_4 )
-            // InternalTestgeneratorDSL.g:11971:3: rule__Loop__StartAssignment_4
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__StartAssignment_4();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getStartAssignment_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__4__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__5"
-    // InternalTestgeneratorDSL.g:11979:1: rule__Loop__Group__5 : rule__Loop__Group__5__Impl rule__Loop__Group__6 ;
-    public final void rule__Loop__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11983:1: ( rule__Loop__Group__5__Impl rule__Loop__Group__6 )
-            // InternalTestgeneratorDSL.g:11984:2: rule__Loop__Group__5__Impl rule__Loop__Group__6
-            {
-            pushFollow(FOLLOW_48);
-            rule__Loop__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__5"
-
-
-    // $ANTLR start "rule__Loop__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:11991:1: rule__Loop__Group__5__Impl : ( 'follows' ) ;
-    public final void rule__Loop__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:11995:1: ( ( 'follows' ) )
-            // InternalTestgeneratorDSL.g:11996:1: ( 'follows' )
-            {
-            // InternalTestgeneratorDSL.g:11996:1: ( 'follows' )
-            // InternalTestgeneratorDSL.g:11997:2: 'follows'
-            {
-             before(grammarAccess.getLoopAccess().getFollowsKeyword_5()); 
-            match(input,62,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getFollowsKeyword_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__5__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__6"
-    // InternalTestgeneratorDSL.g:12006:1: rule__Loop__Group__6 : rule__Loop__Group__6__Impl rule__Loop__Group__7 ;
-    public final void rule__Loop__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12010:1: ( rule__Loop__Group__6__Impl rule__Loop__Group__7 )
-            // InternalTestgeneratorDSL.g:12011:2: rule__Loop__Group__6__Impl rule__Loop__Group__7
-            {
-            pushFollow(FOLLOW_7);
-            rule__Loop__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__6"
-
-
-    // $ANTLR start "rule__Loop__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:12018:1: rule__Loop__Group__6__Impl : ( 'by' ) ;
-    public final void rule__Loop__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12022:1: ( ( 'by' ) )
-            // InternalTestgeneratorDSL.g:12023:1: ( 'by' )
-            {
-            // InternalTestgeneratorDSL.g:12023:1: ( 'by' )
-            // InternalTestgeneratorDSL.g:12024:2: 'by'
-            {
-             before(grammarAccess.getLoopAccess().getByKeyword_6()); 
-            match(input,63,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getByKeyword_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__6__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__7"
-    // InternalTestgeneratorDSL.g:12033:1: rule__Loop__Group__7 : rule__Loop__Group__7__Impl rule__Loop__Group__8 ;
-    public final void rule__Loop__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12037:1: ( rule__Loop__Group__7__Impl rule__Loop__Group__8 )
-            // InternalTestgeneratorDSL.g:12038:2: rule__Loop__Group__7__Impl rule__Loop__Group__8
-            {
-            pushFollow(FOLLOW_49);
-            rule__Loop__Group__7__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__8();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__7"
-
-
-    // $ANTLR start "rule__Loop__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:12045:1: rule__Loop__Group__7__Impl : ( ( rule__Loop__FollowerAssignment_7 ) ) ;
-    public final void rule__Loop__Group__7__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12049:1: ( ( ( rule__Loop__FollowerAssignment_7 ) ) )
-            // InternalTestgeneratorDSL.g:12050:1: ( ( rule__Loop__FollowerAssignment_7 ) )
-            {
-            // InternalTestgeneratorDSL.g:12050:1: ( ( rule__Loop__FollowerAssignment_7 ) )
-            // InternalTestgeneratorDSL.g:12051:2: ( rule__Loop__FollowerAssignment_7 )
-            {
-             before(grammarAccess.getLoopAccess().getFollowerAssignment_7()); 
-            // InternalTestgeneratorDSL.g:12052:2: ( rule__Loop__FollowerAssignment_7 )
-            // InternalTestgeneratorDSL.g:12052:3: rule__Loop__FollowerAssignment_7
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__FollowerAssignment_7();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getFollowerAssignment_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__7__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__8"
-    // InternalTestgeneratorDSL.g:12060:1: rule__Loop__Group__8 : rule__Loop__Group__8__Impl rule__Loop__Group__9 ;
-    public final void rule__Loop__Group__8() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12064:1: ( rule__Loop__Group__8__Impl rule__Loop__Group__9 )
-            // InternalTestgeneratorDSL.g:12065:2: rule__Loop__Group__8__Impl rule__Loop__Group__9
-            {
-            pushFollow(FOLLOW_5);
-            rule__Loop__Group__8__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__9();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__8"
-
-
-    // $ANTLR start "rule__Loop__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:12072:1: rule__Loop__Group__8__Impl : ( 'ends' ) ;
-    public final void rule__Loop__Group__8__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12076:1: ( ( 'ends' ) )
-            // InternalTestgeneratorDSL.g:12077:1: ( 'ends' )
-            {
-            // InternalTestgeneratorDSL.g:12077:1: ( 'ends' )
-            // InternalTestgeneratorDSL.g:12078:2: 'ends'
-            {
-             before(grammarAccess.getLoopAccess().getEndsKeyword_8()); 
-            match(input,64,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getEndsKeyword_8()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__8__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__9"
-    // InternalTestgeneratorDSL.g:12087:1: rule__Loop__Group__9 : rule__Loop__Group__9__Impl rule__Loop__Group__10 ;
-    public final void rule__Loop__Group__9() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12091:1: ( rule__Loop__Group__9__Impl rule__Loop__Group__10 )
-            // InternalTestgeneratorDSL.g:12092:2: rule__Loop__Group__9__Impl rule__Loop__Group__10
-            {
-            pushFollow(FOLLOW_7);
-            rule__Loop__Group__9__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__10();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__9"
-
-
-    // $ANTLR start "rule__Loop__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:12099:1: rule__Loop__Group__9__Impl : ( 'with' ) ;
-    public final void rule__Loop__Group__9__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12103:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:12104:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:12104:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:12105:2: 'with'
-            {
-             before(grammarAccess.getLoopAccess().getWithKeyword_9()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getWithKeyword_9()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__9__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__10"
-    // InternalTestgeneratorDSL.g:12114:1: rule__Loop__Group__10 : rule__Loop__Group__10__Impl rule__Loop__Group__11 ;
-    public final void rule__Loop__Group__10() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12118:1: ( rule__Loop__Group__10__Impl rule__Loop__Group__11 )
-            // InternalTestgeneratorDSL.g:12119:2: rule__Loop__Group__10__Impl rule__Loop__Group__11
-            {
-            pushFollow(FOLLOW_50);
-            rule__Loop__Group__10__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__11();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__10"
-
-
-    // $ANTLR start "rule__Loop__Group__10__Impl"
-    // InternalTestgeneratorDSL.g:12126:1: rule__Loop__Group__10__Impl : ( ( rule__Loop__EndAssignment_10 ) ) ;
-    public final void rule__Loop__Group__10__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12130:1: ( ( ( rule__Loop__EndAssignment_10 ) ) )
-            // InternalTestgeneratorDSL.g:12131:1: ( ( rule__Loop__EndAssignment_10 ) )
-            {
-            // InternalTestgeneratorDSL.g:12131:1: ( ( rule__Loop__EndAssignment_10 ) )
-            // InternalTestgeneratorDSL.g:12132:2: ( rule__Loop__EndAssignment_10 )
-            {
-             before(grammarAccess.getLoopAccess().getEndAssignment_10()); 
-            // InternalTestgeneratorDSL.g:12133:2: ( rule__Loop__EndAssignment_10 )
-            // InternalTestgeneratorDSL.g:12133:3: rule__Loop__EndAssignment_10
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__EndAssignment_10();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getEndAssignment_10()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__10__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__11"
-    // InternalTestgeneratorDSL.g:12141:1: rule__Loop__Group__11 : rule__Loop__Group__11__Impl rule__Loop__Group__12 ;
-    public final void rule__Loop__Group__11() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12145:1: ( rule__Loop__Group__11__Impl rule__Loop__Group__12 )
-            // InternalTestgeneratorDSL.g:12146:2: rule__Loop__Group__11__Impl rule__Loop__Group__12
-            {
-            pushFollow(FOLLOW_51);
-            rule__Loop__Group__11__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__12();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__11"
-
-
-    // $ANTLR start "rule__Loop__Group__11__Impl"
-    // InternalTestgeneratorDSL.g:12153:1: rule__Loop__Group__11__Impl : ( 'has' ) ;
-    public final void rule__Loop__Group__11__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12157:1: ( ( 'has' ) )
-            // InternalTestgeneratorDSL.g:12158:1: ( 'has' )
-            {
-            // InternalTestgeneratorDSL.g:12158:1: ( 'has' )
-            // InternalTestgeneratorDSL.g:12159:2: 'has'
-            {
-             before(grammarAccess.getLoopAccess().getHasKeyword_11()); 
-            match(input,65,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getHasKeyword_11()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__11__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__12"
-    // InternalTestgeneratorDSL.g:12168:1: rule__Loop__Group__12 : rule__Loop__Group__12__Impl rule__Loop__Group__13 ;
-    public final void rule__Loop__Group__12() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12172:1: ( rule__Loop__Group__12__Impl rule__Loop__Group__13 )
-            // InternalTestgeneratorDSL.g:12173:2: rule__Loop__Group__12__Impl rule__Loop__Group__13
-            {
-            pushFollow(FOLLOW_43);
-            rule__Loop__Group__12__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__13();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__12"
-
-
-    // $ANTLR start "rule__Loop__Group__12__Impl"
-    // InternalTestgeneratorDSL.g:12180:1: rule__Loop__Group__12__Impl : ( 'complexity' ) ;
-    public final void rule__Loop__Group__12__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12184:1: ( ( 'complexity' ) )
-            // InternalTestgeneratorDSL.g:12185:1: ( 'complexity' )
-            {
-            // InternalTestgeneratorDSL.g:12185:1: ( 'complexity' )
-            // InternalTestgeneratorDSL.g:12186:2: 'complexity'
-            {
-             before(grammarAccess.getLoopAccess().getComplexityKeyword_12()); 
-            match(input,66,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getComplexityKeyword_12()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__12__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__13"
-    // InternalTestgeneratorDSL.g:12195:1: rule__Loop__Group__13 : rule__Loop__Group__13__Impl rule__Loop__Group__14 ;
-    public final void rule__Loop__Group__13() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12199:1: ( rule__Loop__Group__13__Impl rule__Loop__Group__14 )
-            // InternalTestgeneratorDSL.g:12200:2: rule__Loop__Group__13__Impl rule__Loop__Group__14
-            {
-            pushFollow(FOLLOW_52);
-            rule__Loop__Group__13__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__14();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__13"
-
-
-    // $ANTLR start "rule__Loop__Group__13__Impl"
-    // InternalTestgeneratorDSL.g:12207:1: rule__Loop__Group__13__Impl : ( ( rule__Loop__ComplexityAssignment_13 ) ) ;
-    public final void rule__Loop__Group__13__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12211:1: ( ( ( rule__Loop__ComplexityAssignment_13 ) ) )
-            // InternalTestgeneratorDSL.g:12212:1: ( ( rule__Loop__ComplexityAssignment_13 ) )
-            {
-            // InternalTestgeneratorDSL.g:12212:1: ( ( rule__Loop__ComplexityAssignment_13 ) )
-            // InternalTestgeneratorDSL.g:12213:2: ( rule__Loop__ComplexityAssignment_13 )
-            {
-             before(grammarAccess.getLoopAccess().getComplexityAssignment_13()); 
-            // InternalTestgeneratorDSL.g:12214:2: ( rule__Loop__ComplexityAssignment_13 )
-            // InternalTestgeneratorDSL.g:12214:3: rule__Loop__ComplexityAssignment_13
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__ComplexityAssignment_13();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getComplexityAssignment_13()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__13__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__14"
-    // InternalTestgeneratorDSL.g:12222:1: rule__Loop__Group__14 : rule__Loop__Group__14__Impl rule__Loop__Group__15 ;
-    public final void rule__Loop__Group__14() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12226:1: ( rule__Loop__Group__14__Impl rule__Loop__Group__15 )
-            // InternalTestgeneratorDSL.g:12227:2: rule__Loop__Group__14__Impl rule__Loop__Group__15
-            {
-            pushFollow(FOLLOW_12);
-            rule__Loop__Group__14__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__15();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__14"
-
-
-    // $ANTLR start "rule__Loop__Group__14__Impl"
-    // InternalTestgeneratorDSL.g:12234:1: rule__Loop__Group__14__Impl : ( 'passed' ) ;
-    public final void rule__Loop__Group__14__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12238:1: ( ( 'passed' ) )
-            // InternalTestgeneratorDSL.g:12239:1: ( 'passed' )
-            {
-            // InternalTestgeneratorDSL.g:12239:1: ( 'passed' )
-            // InternalTestgeneratorDSL.g:12240:2: 'passed'
-            {
-             before(grammarAccess.getLoopAccess().getPassedKeyword_14()); 
-            match(input,67,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getPassedKeyword_14()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__14__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__15"
-    // InternalTestgeneratorDSL.g:12249:1: rule__Loop__Group__15 : rule__Loop__Group__15__Impl rule__Loop__Group__16 ;
-    public final void rule__Loop__Group__15() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12253:1: ( rule__Loop__Group__15__Impl rule__Loop__Group__16 )
-            // InternalTestgeneratorDSL.g:12254:2: rule__Loop__Group__15__Impl rule__Loop__Group__16
-            {
-            pushFollow(FOLLOW_13);
-            rule__Loop__Group__15__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__16();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__15"
-
-
-    // $ANTLR start "rule__Loop__Group__15__Impl"
-    // InternalTestgeneratorDSL.g:12261:1: rule__Loop__Group__15__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__Loop__Group__15__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12265:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:12266:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:12266:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:12267:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getASSOCIATIONTerminalRuleCall_15()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__15__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__16"
-    // InternalTestgeneratorDSL.g:12276:1: rule__Loop__Group__16 : rule__Loop__Group__16__Impl rule__Loop__Group__17 ;
-    public final void rule__Loop__Group__16() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12280:1: ( rule__Loop__Group__16__Impl rule__Loop__Group__17 )
-            // InternalTestgeneratorDSL.g:12281:2: rule__Loop__Group__16__Impl rule__Loop__Group__17
-            {
-            pushFollow(FOLLOW_42);
-            rule__Loop__Group__16__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__17();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__16"
-
-
-    // $ANTLR start "rule__Loop__Group__16__Impl"
-    // InternalTestgeneratorDSL.g:12288:1: rule__Loop__Group__16__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__Loop__Group__16__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12292:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:12293:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:12293:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:12294:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__16__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__17"
-    // InternalTestgeneratorDSL.g:12303:1: rule__Loop__Group__17 : rule__Loop__Group__17__Impl rule__Loop__Group__18 ;
-    public final void rule__Loop__Group__17() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12307:1: ( rule__Loop__Group__17__Impl rule__Loop__Group__18 )
-            // InternalTestgeneratorDSL.g:12308:2: rule__Loop__Group__17__Impl rule__Loop__Group__18
-            {
-            pushFollow(FOLLOW_42);
-            rule__Loop__Group__17__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__18();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__17"
-
-
-    // $ANTLR start "rule__Loop__Group__17__Impl"
-    // InternalTestgeneratorDSL.g:12315:1: rule__Loop__Group__17__Impl : ( ( rule__Loop__Group_17__0 )? ) ;
-    public final void rule__Loop__Group__17__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12319:1: ( ( ( rule__Loop__Group_17__0 )? ) )
-            // InternalTestgeneratorDSL.g:12320:1: ( ( rule__Loop__Group_17__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:12320:1: ( ( rule__Loop__Group_17__0 )? )
-            // InternalTestgeneratorDSL.g:12321:2: ( rule__Loop__Group_17__0 )?
-            {
-             before(grammarAccess.getLoopAccess().getGroup_17()); 
-            // InternalTestgeneratorDSL.g:12322:2: ( rule__Loop__Group_17__0 )?
-            int alt88=2;
-            int LA88_0 = input.LA(1);
-
-            if ( (LA88_0==RULE_INT) ) {
-                alt88=1;
-            }
-            switch (alt88) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:12322:3: rule__Loop__Group_17__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Loop__Group_17__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getLoopAccess().getGroup_17()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__17__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__18"
-    // InternalTestgeneratorDSL.g:12330:1: rule__Loop__Group__18 : rule__Loop__Group__18__Impl rule__Loop__Group__19 ;
-    public final void rule__Loop__Group__18() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12334:1: ( rule__Loop__Group__18__Impl rule__Loop__Group__19 )
-            // InternalTestgeneratorDSL.g:12335:2: rule__Loop__Group__18__Impl rule__Loop__Group__19
-            {
-            pushFollow(FOLLOW_24);
-            rule__Loop__Group__18__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__19();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__18"
-
-
-    // $ANTLR start "rule__Loop__Group__18__Impl"
-    // InternalTestgeneratorDSL.g:12342:1: rule__Loop__Group__18__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__Loop__Group__18__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12346:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:12347:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:12347:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:12348:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getLIST_CLOSEDTerminalRuleCall_18()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__18__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group__19"
-    // InternalTestgeneratorDSL.g:12357:1: rule__Loop__Group__19 : rule__Loop__Group__19__Impl ;
-    public final void rule__Loop__Group__19() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12361:1: ( rule__Loop__Group__19__Impl )
-            // InternalTestgeneratorDSL.g:12362:2: rule__Loop__Group__19__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group__19__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__19"
-
-
-    // $ANTLR start "rule__Loop__Group__19__Impl"
-    // InternalTestgeneratorDSL.g:12368:1: rule__Loop__Group__19__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__Loop__Group__19__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12372:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:12373:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:12373:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:12374:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getDECLARATION_FINISHEDTerminalRuleCall_19()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group__19__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group_17__0"
-    // InternalTestgeneratorDSL.g:12384:1: rule__Loop__Group_17__0 : rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1 ;
-    public final void rule__Loop__Group_17__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12388:1: ( rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1 )
-            // InternalTestgeneratorDSL.g:12389:2: rule__Loop__Group_17__0__Impl rule__Loop__Group_17__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__Loop__Group_17__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group_17__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17__0"
-
-
-    // $ANTLR start "rule__Loop__Group_17__0__Impl"
-    // InternalTestgeneratorDSL.g:12396:1: rule__Loop__Group_17__0__Impl : ( ( rule__Loop__FrequenciesAssignment_17_0 ) ) ;
-    public final void rule__Loop__Group_17__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12400:1: ( ( ( rule__Loop__FrequenciesAssignment_17_0 ) ) )
-            // InternalTestgeneratorDSL.g:12401:1: ( ( rule__Loop__FrequenciesAssignment_17_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:12401:1: ( ( rule__Loop__FrequenciesAssignment_17_0 ) )
-            // InternalTestgeneratorDSL.g:12402:2: ( rule__Loop__FrequenciesAssignment_17_0 )
-            {
-             before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); 
-            // InternalTestgeneratorDSL.g:12403:2: ( rule__Loop__FrequenciesAssignment_17_0 )
-            // InternalTestgeneratorDSL.g:12403:3: rule__Loop__FrequenciesAssignment_17_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__FrequenciesAssignment_17_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17__0__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group_17__1"
-    // InternalTestgeneratorDSL.g:12411:1: rule__Loop__Group_17__1 : rule__Loop__Group_17__1__Impl ;
-    public final void rule__Loop__Group_17__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12415:1: ( rule__Loop__Group_17__1__Impl )
-            // InternalTestgeneratorDSL.g:12416:2: rule__Loop__Group_17__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group_17__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17__1"
-
-
-    // $ANTLR start "rule__Loop__Group_17__1__Impl"
-    // InternalTestgeneratorDSL.g:12422:1: rule__Loop__Group_17__1__Impl : ( ( rule__Loop__Group_17_1__0 )* ) ;
-    public final void rule__Loop__Group_17__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12426:1: ( ( ( rule__Loop__Group_17_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:12427:1: ( ( rule__Loop__Group_17_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:12427:1: ( ( rule__Loop__Group_17_1__0 )* )
-            // InternalTestgeneratorDSL.g:12428:2: ( rule__Loop__Group_17_1__0 )*
-            {
-             before(grammarAccess.getLoopAccess().getGroup_17_1()); 
-            // InternalTestgeneratorDSL.g:12429:2: ( rule__Loop__Group_17_1__0 )*
-            loop89:
-            do {
-                int alt89=2;
-                int LA89_0 = input.LA(1);
-
-                if ( (LA89_0==RULE_SEPARATOR) ) {
-                    alt89=1;
-                }
-
-
-                switch (alt89) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:12429:3: rule__Loop__Group_17_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__Loop__Group_17_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop89;
-                }
-            } while (true);
-
-             after(grammarAccess.getLoopAccess().getGroup_17_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17__1__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group_17_1__0"
-    // InternalTestgeneratorDSL.g:12438:1: rule__Loop__Group_17_1__0 : rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1 ;
-    public final void rule__Loop__Group_17_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12442:1: ( rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1 )
-            // InternalTestgeneratorDSL.g:12443:2: rule__Loop__Group_17_1__0__Impl rule__Loop__Group_17_1__1
-            {
-            pushFollow(FOLLOW_43);
-            rule__Loop__Group_17_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group_17_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17_1__0"
-
-
-    // $ANTLR start "rule__Loop__Group_17_1__0__Impl"
-    // InternalTestgeneratorDSL.g:12450:1: rule__Loop__Group_17_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__Loop__Group_17_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12454:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:12455:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:12455:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:12456:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17_1__0__Impl"
-
-
-    // $ANTLR start "rule__Loop__Group_17_1__1"
-    // InternalTestgeneratorDSL.g:12465:1: rule__Loop__Group_17_1__1 : rule__Loop__Group_17_1__1__Impl ;
-    public final void rule__Loop__Group_17_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12469:1: ( rule__Loop__Group_17_1__1__Impl )
-            // InternalTestgeneratorDSL.g:12470:2: rule__Loop__Group_17_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__Group_17_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17_1__1"
-
-
-    // $ANTLR start "rule__Loop__Group_17_1__1__Impl"
-    // InternalTestgeneratorDSL.g:12476:1: rule__Loop__Group_17_1__1__Impl : ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) ) ;
-    public final void rule__Loop__Group_17_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12480:1: ( ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:12481:1: ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:12481:1: ( ( rule__Loop__FrequenciesAssignment_17_1_1 ) )
-            // InternalTestgeneratorDSL.g:12482:2: ( rule__Loop__FrequenciesAssignment_17_1_1 )
-            {
-             before(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); 
-            // InternalTestgeneratorDSL.g:12483:2: ( rule__Loop__FrequenciesAssignment_17_1_1 )
-            // InternalTestgeneratorDSL.g:12483:3: rule__Loop__FrequenciesAssignment_17_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Loop__FrequenciesAssignment_17_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getLoopAccess().getFrequenciesAssignment_17_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Loop__Group_17_1__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__0"
-    // InternalTestgeneratorDSL.g:12492:1: rule__Flow__Group__0 : rule__Flow__Group__0__Impl rule__Flow__Group__1 ;
-    public final void rule__Flow__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12496:1: ( rule__Flow__Group__0__Impl rule__Flow__Group__1 )
-            // InternalTestgeneratorDSL.g:12497:2: rule__Flow__Group__0__Impl rule__Flow__Group__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Flow__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__0"
-
-
-    // $ANTLR start "rule__Flow__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:12504:1: rule__Flow__Group__0__Impl : ( 'Flow' ) ;
-    public final void rule__Flow__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12508:1: ( ( 'Flow' ) )
-            // InternalTestgeneratorDSL.g:12509:1: ( 'Flow' )
-            {
-            // InternalTestgeneratorDSL.g:12509:1: ( 'Flow' )
-            // InternalTestgeneratorDSL.g:12510:2: 'Flow'
-            {
-             before(grammarAccess.getFlowAccess().getFlowKeyword_0()); 
-            match(input,68,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getFlowKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__1"
-    // InternalTestgeneratorDSL.g:12519:1: rule__Flow__Group__1 : rule__Flow__Group__1__Impl rule__Flow__Group__2 ;
-    public final void rule__Flow__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12523:1: ( rule__Flow__Group__1__Impl rule__Flow__Group__2 )
-            // InternalTestgeneratorDSL.g:12524:2: rule__Flow__Group__1__Impl rule__Flow__Group__2
-            {
-            pushFollow(FOLLOW_53);
-            rule__Flow__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__1"
-
-
-    // $ANTLR start "rule__Flow__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:12531:1: rule__Flow__Group__1__Impl : ( ( rule__Flow__NameAssignment_1 ) ) ;
-    public final void rule__Flow__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12535:1: ( ( ( rule__Flow__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:12536:1: ( ( rule__Flow__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:12536:1: ( ( rule__Flow__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:12537:2: ( rule__Flow__NameAssignment_1 )
-            {
-             before(grammarAccess.getFlowAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:12538:2: ( rule__Flow__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:12538:3: rule__Flow__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getNameAssignment_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__2"
-    // InternalTestgeneratorDSL.g:12546:1: rule__Flow__Group__2 : rule__Flow__Group__2__Impl rule__Flow__Group__3 ;
-    public final void rule__Flow__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12550:1: ( rule__Flow__Group__2__Impl rule__Flow__Group__3 )
-            // InternalTestgeneratorDSL.g:12551:2: rule__Flow__Group__2__Impl rule__Flow__Group__3
-            {
-            pushFollow(FOLLOW_4);
-            rule__Flow__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__2"
-
-
-    // $ANTLR start "rule__Flow__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:12558:1: rule__Flow__Group__2__Impl : ( 'for' ) ;
-    public final void rule__Flow__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12562:1: ( ( 'for' ) )
-            // InternalTestgeneratorDSL.g:12563:1: ( 'for' )
-            {
-            // InternalTestgeneratorDSL.g:12563:1: ( 'for' )
-            // InternalTestgeneratorDSL.g:12564:2: 'for'
-            {
-             before(grammarAccess.getFlowAccess().getForKeyword_2()); 
-            match(input,69,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getForKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__2__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__3"
-    // InternalTestgeneratorDSL.g:12573:1: rule__Flow__Group__3 : rule__Flow__Group__3__Impl rule__Flow__Group__4 ;
-    public final void rule__Flow__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12577:1: ( rule__Flow__Group__3__Impl rule__Flow__Group__4 )
-            // InternalTestgeneratorDSL.g:12578:2: rule__Flow__Group__3__Impl rule__Flow__Group__4
-            {
-            pushFollow(FOLLOW_5);
-            rule__Flow__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__3"
-
-
-    // $ANTLR start "rule__Flow__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:12585:1: rule__Flow__Group__3__Impl : ( ( rule__Flow__BpmnReferenceAssignment_3 ) ) ;
-    public final void rule__Flow__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12589:1: ( ( ( rule__Flow__BpmnReferenceAssignment_3 ) ) )
-            // InternalTestgeneratorDSL.g:12590:1: ( ( rule__Flow__BpmnReferenceAssignment_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:12590:1: ( ( rule__Flow__BpmnReferenceAssignment_3 ) )
-            // InternalTestgeneratorDSL.g:12591:2: ( rule__Flow__BpmnReferenceAssignment_3 )
-            {
-             before(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); 
-            // InternalTestgeneratorDSL.g:12592:2: ( rule__Flow__BpmnReferenceAssignment_3 )
-            // InternalTestgeneratorDSL.g:12592:3: rule__Flow__BpmnReferenceAssignment_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__BpmnReferenceAssignment_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getBpmnReferenceAssignment_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__3__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__4"
-    // InternalTestgeneratorDSL.g:12600:1: rule__Flow__Group__4 : rule__Flow__Group__4__Impl rule__Flow__Group__5 ;
-    public final void rule__Flow__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12604:1: ( rule__Flow__Group__4__Impl rule__Flow__Group__5 )
-            // InternalTestgeneratorDSL.g:12605:2: rule__Flow__Group__4__Impl rule__Flow__Group__5
-            {
-            pushFollow(FOLLOW_5);
-            rule__Flow__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__4"
-
-
-    // $ANTLR start "rule__Flow__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:12612:1: rule__Flow__Group__4__Impl : ( ( rule__Flow__Group_4__0 )? ) ;
-    public final void rule__Flow__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12616:1: ( ( ( rule__Flow__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:12617:1: ( ( rule__Flow__Group_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:12617:1: ( ( rule__Flow__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:12618:2: ( rule__Flow__Group_4__0 )?
-            {
-             before(grammarAccess.getFlowAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:12619:2: ( rule__Flow__Group_4__0 )?
-            int alt90=2;
-            int LA90_0 = input.LA(1);
-
-            if ( (LA90_0==28) ) {
-                int LA90_1 = input.LA(2);
-
-                if ( (LA90_1==71) ) {
-                    alt90=1;
-                }
-            }
-            switch (alt90) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:12619:3: rule__Flow__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Flow__Group_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getFlowAccess().getGroup_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__4__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__5"
-    // InternalTestgeneratorDSL.g:12627:1: rule__Flow__Group__5 : rule__Flow__Group__5__Impl rule__Flow__Group__6 ;
-    public final void rule__Flow__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12631:1: ( rule__Flow__Group__5__Impl rule__Flow__Group__6 )
-            // InternalTestgeneratorDSL.g:12632:2: rule__Flow__Group__5__Impl rule__Flow__Group__6
-            {
-            pushFollow(FOLLOW_54);
-            rule__Flow__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__5"
-
-
-    // $ANTLR start "rule__Flow__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:12639:1: rule__Flow__Group__5__Impl : ( 'with' ) ;
-    public final void rule__Flow__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12643:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:12644:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:12644:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:12645:2: 'with'
-            {
-             before(grammarAccess.getFlowAccess().getWithKeyword_5()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getWithKeyword_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__5__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__6"
-    // InternalTestgeneratorDSL.g:12654:1: rule__Flow__Group__6 : rule__Flow__Group__6__Impl rule__Flow__Group__7 ;
-    public final void rule__Flow__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12658:1: ( rule__Flow__Group__6__Impl rule__Flow__Group__7 )
-            // InternalTestgeneratorDSL.g:12659:2: rule__Flow__Group__6__Impl rule__Flow__Group__7
-            {
-            pushFollow(FOLLOW_12);
-            rule__Flow__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__6"
-
-
-    // $ANTLR start "rule__Flow__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:12666:1: rule__Flow__Group__6__Impl : ( 'elements' ) ;
-    public final void rule__Flow__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12670:1: ( ( 'elements' ) )
-            // InternalTestgeneratorDSL.g:12671:1: ( 'elements' )
-            {
-            // InternalTestgeneratorDSL.g:12671:1: ( 'elements' )
-            // InternalTestgeneratorDSL.g:12672:2: 'elements'
-            {
-             before(grammarAccess.getFlowAccess().getElementsKeyword_6()); 
-            match(input,70,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getElementsKeyword_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__6__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__7"
-    // InternalTestgeneratorDSL.g:12681:1: rule__Flow__Group__7 : rule__Flow__Group__7__Impl rule__Flow__Group__8 ;
-    public final void rule__Flow__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12685:1: ( rule__Flow__Group__7__Impl rule__Flow__Group__8 )
-            // InternalTestgeneratorDSL.g:12686:2: rule__Flow__Group__7__Impl rule__Flow__Group__8
-            {
-            pushFollow(FOLLOW_13);
-            rule__Flow__Group__7__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__8();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__7"
-
-
-    // $ANTLR start "rule__Flow__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:12693:1: rule__Flow__Group__7__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__Flow__Group__7__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12697:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:12698:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:12698:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:12699:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__7__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__8"
-    // InternalTestgeneratorDSL.g:12708:1: rule__Flow__Group__8 : rule__Flow__Group__8__Impl rule__Flow__Group__9 ;
-    public final void rule__Flow__Group__8() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12712:1: ( rule__Flow__Group__8__Impl rule__Flow__Group__9 )
-            // InternalTestgeneratorDSL.g:12713:2: rule__Flow__Group__8__Impl rule__Flow__Group__9
-            {
-            pushFollow(FOLLOW_21);
-            rule__Flow__Group__8__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__9();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__8"
-
-
-    // $ANTLR start "rule__Flow__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:12720:1: rule__Flow__Group__8__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__Flow__Group__8__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12724:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:12725:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:12725:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:12726:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__8__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__9"
-    // InternalTestgeneratorDSL.g:12735:1: rule__Flow__Group__9 : rule__Flow__Group__9__Impl rule__Flow__Group__10 ;
-    public final void rule__Flow__Group__9() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12739:1: ( rule__Flow__Group__9__Impl rule__Flow__Group__10 )
-            // InternalTestgeneratorDSL.g:12740:2: rule__Flow__Group__9__Impl rule__Flow__Group__10
-            {
-            pushFollow(FOLLOW_21);
-            rule__Flow__Group__9__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__10();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__9"
-
-
-    // $ANTLR start "rule__Flow__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:12747:1: rule__Flow__Group__9__Impl : ( ( rule__Flow__Group_9__0 )? ) ;
-    public final void rule__Flow__Group__9__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12751:1: ( ( ( rule__Flow__Group_9__0 )? ) )
-            // InternalTestgeneratorDSL.g:12752:1: ( ( rule__Flow__Group_9__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:12752:1: ( ( rule__Flow__Group_9__0 )? )
-            // InternalTestgeneratorDSL.g:12753:2: ( rule__Flow__Group_9__0 )?
-            {
-             before(grammarAccess.getFlowAccess().getGroup_9()); 
-            // InternalTestgeneratorDSL.g:12754:2: ( rule__Flow__Group_9__0 )?
-            int alt91=2;
-            int LA91_0 = input.LA(1);
-
-            if ( (LA91_0==RULE_ID) ) {
-                alt91=1;
-            }
-            switch (alt91) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:12754:3: rule__Flow__Group_9__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Flow__Group_9__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getFlowAccess().getGroup_9()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__9__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__10"
-    // InternalTestgeneratorDSL.g:12762:1: rule__Flow__Group__10 : rule__Flow__Group__10__Impl rule__Flow__Group__11 ;
-    public final void rule__Flow__Group__10() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12766:1: ( rule__Flow__Group__10__Impl rule__Flow__Group__11 )
-            // InternalTestgeneratorDSL.g:12767:2: rule__Flow__Group__10__Impl rule__Flow__Group__11
-            {
-            pushFollow(FOLLOW_55);
-            rule__Flow__Group__10__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__11();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__10"
-
-
-    // $ANTLR start "rule__Flow__Group__10__Impl"
-    // InternalTestgeneratorDSL.g:12774:1: rule__Flow__Group__10__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__Flow__Group__10__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12778:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:12779:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:12779:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:12780:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__10__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__11"
-    // InternalTestgeneratorDSL.g:12789:1: rule__Flow__Group__11 : rule__Flow__Group__11__Impl rule__Flow__Group__12 ;
-    public final void rule__Flow__Group__11() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12793:1: ( rule__Flow__Group__11__Impl rule__Flow__Group__12 )
-            // InternalTestgeneratorDSL.g:12794:2: rule__Flow__Group__11__Impl rule__Flow__Group__12
-            {
-            pushFollow(FOLLOW_55);
-            rule__Flow__Group__11__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__12();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__11"
-
-
-    // $ANTLR start "rule__Flow__Group__11__Impl"
-    // InternalTestgeneratorDSL.g:12801:1: rule__Flow__Group__11__Impl : ( ( rule__Flow__Group_11__0 )? ) ;
-    public final void rule__Flow__Group__11__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12805:1: ( ( ( rule__Flow__Group_11__0 )? ) )
-            // InternalTestgeneratorDSL.g:12806:1: ( ( rule__Flow__Group_11__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:12806:1: ( ( rule__Flow__Group_11__0 )? )
-            // InternalTestgeneratorDSL.g:12807:2: ( rule__Flow__Group_11__0 )?
-            {
-             before(grammarAccess.getFlowAccess().getGroup_11()); 
-            // InternalTestgeneratorDSL.g:12808:2: ( rule__Flow__Group_11__0 )?
-            int alt92=2;
-            int LA92_0 = input.LA(1);
-
-            if ( (LA92_0==72) ) {
-                alt92=1;
-            }
-            switch (alt92) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:12808:3: rule__Flow__Group_11__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Flow__Group_11__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getFlowAccess().getGroup_11()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__11__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group__12"
-    // InternalTestgeneratorDSL.g:12816:1: rule__Flow__Group__12 : rule__Flow__Group__12__Impl ;
-    public final void rule__Flow__Group__12() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12820:1: ( rule__Flow__Group__12__Impl )
-            // InternalTestgeneratorDSL.g:12821:2: rule__Flow__Group__12__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group__12__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__12"
-
-
-    // $ANTLR start "rule__Flow__Group__12__Impl"
-    // InternalTestgeneratorDSL.g:12827:1: rule__Flow__Group__12__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__Flow__Group__12__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12831:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:12832:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:12832:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:12833:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getDECLARATION_FINISHEDTerminalRuleCall_12()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group__12__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_4__0"
-    // InternalTestgeneratorDSL.g:12843:1: rule__Flow__Group_4__0 : rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1 ;
-    public final void rule__Flow__Group_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12847:1: ( rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1 )
-            // InternalTestgeneratorDSL.g:12848:2: rule__Flow__Group_4__0__Impl rule__Flow__Group_4__1
-            {
-            pushFollow(FOLLOW_56);
-            rule__Flow__Group_4__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_4__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__0"
-
-
-    // $ANTLR start "rule__Flow__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:12855:1: rule__Flow__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__Flow__Group_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12859:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:12860:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:12860:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:12861:2: 'with'
-            {
-             before(grammarAccess.getFlowAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getWithKeyword_4_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_4__1"
-    // InternalTestgeneratorDSL.g:12870:1: rule__Flow__Group_4__1 : rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2 ;
-    public final void rule__Flow__Group_4__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12874:1: ( rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2 )
-            // InternalTestgeneratorDSL.g:12875:2: rule__Flow__Group_4__1__Impl rule__Flow__Group_4__2
-            {
-            pushFollow(FOLLOW_12);
-            rule__Flow__Group_4__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_4__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__1"
-
-
-    // $ANTLR start "rule__Flow__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:12882:1: rule__Flow__Group_4__1__Impl : ( 'flag' ) ;
-    public final void rule__Flow__Group_4__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12886:1: ( ( 'flag' ) )
-            // InternalTestgeneratorDSL.g:12887:1: ( 'flag' )
-            {
-            // InternalTestgeneratorDSL.g:12887:1: ( 'flag' )
-            // InternalTestgeneratorDSL.g:12888:2: 'flag'
-            {
-             before(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); 
-            match(input,71,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getFlagKeyword_4_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_4__2"
-    // InternalTestgeneratorDSL.g:12897:1: rule__Flow__Group_4__2 : rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3 ;
-    public final void rule__Flow__Group_4__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12901:1: ( rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3 )
-            // InternalTestgeneratorDSL.g:12902:2: rule__Flow__Group_4__2__Impl rule__Flow__Group_4__3
-            {
-            pushFollow(FOLLOW_57);
-            rule__Flow__Group_4__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_4__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__2"
-
-
-    // $ANTLR start "rule__Flow__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:12909:1: rule__Flow__Group_4__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__Flow__Group_4__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12913:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:12914:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:12914:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:12915:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__2__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_4__3"
-    // InternalTestgeneratorDSL.g:12924:1: rule__Flow__Group_4__3 : rule__Flow__Group_4__3__Impl ;
-    public final void rule__Flow__Group_4__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12928:1: ( rule__Flow__Group_4__3__Impl )
-            // InternalTestgeneratorDSL.g:12929:2: rule__Flow__Group_4__3__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_4__3__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__3"
-
-
-    // $ANTLR start "rule__Flow__Group_4__3__Impl"
-    // InternalTestgeneratorDSL.g:12935:1: rule__Flow__Group_4__3__Impl : ( ( rule__Flow__FlagAssignment_4_3 ) ) ;
-    public final void rule__Flow__Group_4__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12939:1: ( ( ( rule__Flow__FlagAssignment_4_3 ) ) )
-            // InternalTestgeneratorDSL.g:12940:1: ( ( rule__Flow__FlagAssignment_4_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:12940:1: ( ( rule__Flow__FlagAssignment_4_3 ) )
-            // InternalTestgeneratorDSL.g:12941:2: ( rule__Flow__FlagAssignment_4_3 )
-            {
-             before(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); 
-            // InternalTestgeneratorDSL.g:12942:2: ( rule__Flow__FlagAssignment_4_3 )
-            // InternalTestgeneratorDSL.g:12942:3: rule__Flow__FlagAssignment_4_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__FlagAssignment_4_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getFlagAssignment_4_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_4__3__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_9__0"
-    // InternalTestgeneratorDSL.g:12951:1: rule__Flow__Group_9__0 : rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1 ;
-    public final void rule__Flow__Group_9__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12955:1: ( rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1 )
-            // InternalTestgeneratorDSL.g:12956:2: rule__Flow__Group_9__0__Impl rule__Flow__Group_9__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__Flow__Group_9__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_9__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9__0"
-
-
-    // $ANTLR start "rule__Flow__Group_9__0__Impl"
-    // InternalTestgeneratorDSL.g:12963:1: rule__Flow__Group_9__0__Impl : ( ( rule__Flow__InclElementsAssignment_9_0 ) ) ;
-    public final void rule__Flow__Group_9__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12967:1: ( ( ( rule__Flow__InclElementsAssignment_9_0 ) ) )
-            // InternalTestgeneratorDSL.g:12968:1: ( ( rule__Flow__InclElementsAssignment_9_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:12968:1: ( ( rule__Flow__InclElementsAssignment_9_0 ) )
-            // InternalTestgeneratorDSL.g:12969:2: ( rule__Flow__InclElementsAssignment_9_0 )
-            {
-             before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); 
-            // InternalTestgeneratorDSL.g:12970:2: ( rule__Flow__InclElementsAssignment_9_0 )
-            // InternalTestgeneratorDSL.g:12970:3: rule__Flow__InclElementsAssignment_9_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__InclElementsAssignment_9_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_9__1"
-    // InternalTestgeneratorDSL.g:12978:1: rule__Flow__Group_9__1 : rule__Flow__Group_9__1__Impl ;
-    public final void rule__Flow__Group_9__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12982:1: ( rule__Flow__Group_9__1__Impl )
-            // InternalTestgeneratorDSL.g:12983:2: rule__Flow__Group_9__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_9__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9__1"
-
-
-    // $ANTLR start "rule__Flow__Group_9__1__Impl"
-    // InternalTestgeneratorDSL.g:12989:1: rule__Flow__Group_9__1__Impl : ( ( rule__Flow__Group_9_1__0 )* ) ;
-    public final void rule__Flow__Group_9__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:12993:1: ( ( ( rule__Flow__Group_9_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:12994:1: ( ( rule__Flow__Group_9_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:12994:1: ( ( rule__Flow__Group_9_1__0 )* )
-            // InternalTestgeneratorDSL.g:12995:2: ( rule__Flow__Group_9_1__0 )*
-            {
-             before(grammarAccess.getFlowAccess().getGroup_9_1()); 
-            // InternalTestgeneratorDSL.g:12996:2: ( rule__Flow__Group_9_1__0 )*
-            loop93:
-            do {
-                int alt93=2;
-                int LA93_0 = input.LA(1);
-
-                if ( (LA93_0==RULE_SEPARATOR) ) {
-                    alt93=1;
-                }
-
-
-                switch (alt93) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:12996:3: rule__Flow__Group_9_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__Flow__Group_9_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop93;
-                }
-            } while (true);
-
-             after(grammarAccess.getFlowAccess().getGroup_9_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_9_1__0"
-    // InternalTestgeneratorDSL.g:13005:1: rule__Flow__Group_9_1__0 : rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1 ;
-    public final void rule__Flow__Group_9_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13009:1: ( rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1 )
-            // InternalTestgeneratorDSL.g:13010:2: rule__Flow__Group_9_1__0__Impl rule__Flow__Group_9_1__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Flow__Group_9_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_9_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9_1__0"
-
-
-    // $ANTLR start "rule__Flow__Group_9_1__0__Impl"
-    // InternalTestgeneratorDSL.g:13017:1: rule__Flow__Group_9_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__Flow__Group_9_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13021:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:13022:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:13022:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:13023:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9_1__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_9_1__1"
-    // InternalTestgeneratorDSL.g:13032:1: rule__Flow__Group_9_1__1 : rule__Flow__Group_9_1__1__Impl ;
-    public final void rule__Flow__Group_9_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13036:1: ( rule__Flow__Group_9_1__1__Impl )
-            // InternalTestgeneratorDSL.g:13037:2: rule__Flow__Group_9_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_9_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9_1__1"
-
-
-    // $ANTLR start "rule__Flow__Group_9_1__1__Impl"
-    // InternalTestgeneratorDSL.g:13043:1: rule__Flow__Group_9_1__1__Impl : ( ( rule__Flow__InclElementsAssignment_9_1_1 ) ) ;
-    public final void rule__Flow__Group_9_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13047:1: ( ( ( rule__Flow__InclElementsAssignment_9_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:13048:1: ( ( rule__Flow__InclElementsAssignment_9_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:13048:1: ( ( rule__Flow__InclElementsAssignment_9_1_1 ) )
-            // InternalTestgeneratorDSL.g:13049:2: ( rule__Flow__InclElementsAssignment_9_1_1 )
-            {
-             before(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); 
-            // InternalTestgeneratorDSL.g:13050:2: ( rule__Flow__InclElementsAssignment_9_1_1 )
-            // InternalTestgeneratorDSL.g:13050:3: rule__Flow__InclElementsAssignment_9_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__InclElementsAssignment_9_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getInclElementsAssignment_9_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_9_1__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__0"
-    // InternalTestgeneratorDSL.g:13059:1: rule__Flow__Group_11__0 : rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1 ;
-    public final void rule__Flow__Group_11__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13063:1: ( rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1 )
-            // InternalTestgeneratorDSL.g:13064:2: rule__Flow__Group_11__0__Impl rule__Flow__Group_11__1
-            {
-            pushFollow(FOLLOW_54);
-            rule__Flow__Group_11__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__0"
-
-
-    // $ANTLR start "rule__Flow__Group_11__0__Impl"
-    // InternalTestgeneratorDSL.g:13071:1: rule__Flow__Group_11__0__Impl : ( 'without' ) ;
-    public final void rule__Flow__Group_11__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13075:1: ( ( 'without' ) )
-            // InternalTestgeneratorDSL.g:13076:1: ( 'without' )
-            {
-            // InternalTestgeneratorDSL.g:13076:1: ( 'without' )
-            // InternalTestgeneratorDSL.g:13077:2: 'without'
-            {
-             before(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); 
-            match(input,72,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getWithoutKeyword_11_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__1"
-    // InternalTestgeneratorDSL.g:13086:1: rule__Flow__Group_11__1 : rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2 ;
-    public final void rule__Flow__Group_11__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13090:1: ( rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2 )
-            // InternalTestgeneratorDSL.g:13091:2: rule__Flow__Group_11__1__Impl rule__Flow__Group_11__2
-            {
-            pushFollow(FOLLOW_12);
-            rule__Flow__Group_11__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__1"
-
-
-    // $ANTLR start "rule__Flow__Group_11__1__Impl"
-    // InternalTestgeneratorDSL.g:13098:1: rule__Flow__Group_11__1__Impl : ( 'elements' ) ;
-    public final void rule__Flow__Group_11__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13102:1: ( ( 'elements' ) )
-            // InternalTestgeneratorDSL.g:13103:1: ( 'elements' )
-            {
-            // InternalTestgeneratorDSL.g:13103:1: ( 'elements' )
-            // InternalTestgeneratorDSL.g:13104:2: 'elements'
-            {
-             before(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); 
-            match(input,70,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getElementsKeyword_11_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__2"
-    // InternalTestgeneratorDSL.g:13113:1: rule__Flow__Group_11__2 : rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3 ;
-    public final void rule__Flow__Group_11__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13117:1: ( rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3 )
-            // InternalTestgeneratorDSL.g:13118:2: rule__Flow__Group_11__2__Impl rule__Flow__Group_11__3
-            {
-            pushFollow(FOLLOW_13);
-            rule__Flow__Group_11__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__2"
-
-
-    // $ANTLR start "rule__Flow__Group_11__2__Impl"
-    // InternalTestgeneratorDSL.g:13125:1: rule__Flow__Group_11__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__Flow__Group_11__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13129:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:13130:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:13130:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:13131:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__2__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__3"
-    // InternalTestgeneratorDSL.g:13140:1: rule__Flow__Group_11__3 : rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4 ;
-    public final void rule__Flow__Group_11__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13144:1: ( rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4 )
-            // InternalTestgeneratorDSL.g:13145:2: rule__Flow__Group_11__3__Impl rule__Flow__Group_11__4
-            {
-            pushFollow(FOLLOW_21);
-            rule__Flow__Group_11__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__3"
-
-
-    // $ANTLR start "rule__Flow__Group_11__3__Impl"
-    // InternalTestgeneratorDSL.g:13152:1: rule__Flow__Group_11__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__Flow__Group_11__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13156:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:13157:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:13157:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:13158:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__3__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__4"
-    // InternalTestgeneratorDSL.g:13167:1: rule__Flow__Group_11__4 : rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5 ;
-    public final void rule__Flow__Group_11__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13171:1: ( rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5 )
-            // InternalTestgeneratorDSL.g:13172:2: rule__Flow__Group_11__4__Impl rule__Flow__Group_11__5
-            {
-            pushFollow(FOLLOW_21);
-            rule__Flow__Group_11__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__4"
-
-
-    // $ANTLR start "rule__Flow__Group_11__4__Impl"
-    // InternalTestgeneratorDSL.g:13179:1: rule__Flow__Group_11__4__Impl : ( ( rule__Flow__Group_11_4__0 )? ) ;
-    public final void rule__Flow__Group_11__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13183:1: ( ( ( rule__Flow__Group_11_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:13184:1: ( ( rule__Flow__Group_11_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:13184:1: ( ( rule__Flow__Group_11_4__0 )? )
-            // InternalTestgeneratorDSL.g:13185:2: ( rule__Flow__Group_11_4__0 )?
-            {
-             before(grammarAccess.getFlowAccess().getGroup_11_4()); 
-            // InternalTestgeneratorDSL.g:13186:2: ( rule__Flow__Group_11_4__0 )?
-            int alt94=2;
-            int LA94_0 = input.LA(1);
-
-            if ( (LA94_0==RULE_ID) ) {
-                alt94=1;
-            }
-            switch (alt94) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13186:3: rule__Flow__Group_11_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Flow__Group_11_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getFlowAccess().getGroup_11_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__4__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11__5"
-    // InternalTestgeneratorDSL.g:13194:1: rule__Flow__Group_11__5 : rule__Flow__Group_11__5__Impl ;
-    public final void rule__Flow__Group_11__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13198:1: ( rule__Flow__Group_11__5__Impl )
-            // InternalTestgeneratorDSL.g:13199:2: rule__Flow__Group_11__5__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11__5__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__5"
-
-
-    // $ANTLR start "rule__Flow__Group_11__5__Impl"
-    // InternalTestgeneratorDSL.g:13205:1: rule__Flow__Group_11__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__Flow__Group_11__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13209:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:13210:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:13210:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:13211:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_11_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11__5__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4__0"
-    // InternalTestgeneratorDSL.g:13221:1: rule__Flow__Group_11_4__0 : rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1 ;
-    public final void rule__Flow__Group_11_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13225:1: ( rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1 )
-            // InternalTestgeneratorDSL.g:13226:2: rule__Flow__Group_11_4__0__Impl rule__Flow__Group_11_4__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__Flow__Group_11_4__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11_4__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4__0"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4__0__Impl"
-    // InternalTestgeneratorDSL.g:13233:1: rule__Flow__Group_11_4__0__Impl : ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) ) ;
-    public final void rule__Flow__Group_11_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13237:1: ( ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:13238:1: ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:13238:1: ( ( rule__Flow__ExclElementsAssignment_11_4_0 ) )
-            // InternalTestgeneratorDSL.g:13239:2: ( rule__Flow__ExclElementsAssignment_11_4_0 )
-            {
-             before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); 
-            // InternalTestgeneratorDSL.g:13240:2: ( rule__Flow__ExclElementsAssignment_11_4_0 )
-            // InternalTestgeneratorDSL.g:13240:3: rule__Flow__ExclElementsAssignment_11_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__ExclElementsAssignment_11_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4__1"
-    // InternalTestgeneratorDSL.g:13248:1: rule__Flow__Group_11_4__1 : rule__Flow__Group_11_4__1__Impl ;
-    public final void rule__Flow__Group_11_4__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13252:1: ( rule__Flow__Group_11_4__1__Impl )
-            // InternalTestgeneratorDSL.g:13253:2: rule__Flow__Group_11_4__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11_4__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4__1"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4__1__Impl"
-    // InternalTestgeneratorDSL.g:13259:1: rule__Flow__Group_11_4__1__Impl : ( ( rule__Flow__Group_11_4_1__0 )* ) ;
-    public final void rule__Flow__Group_11_4__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13263:1: ( ( ( rule__Flow__Group_11_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:13264:1: ( ( rule__Flow__Group_11_4_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:13264:1: ( ( rule__Flow__Group_11_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:13265:2: ( rule__Flow__Group_11_4_1__0 )*
-            {
-             before(grammarAccess.getFlowAccess().getGroup_11_4_1()); 
-            // InternalTestgeneratorDSL.g:13266:2: ( rule__Flow__Group_11_4_1__0 )*
-            loop95:
-            do {
-                int alt95=2;
-                int LA95_0 = input.LA(1);
-
-                if ( (LA95_0==RULE_SEPARATOR) ) {
-                    alt95=1;
-                }
-
-
-                switch (alt95) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:13266:3: rule__Flow__Group_11_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__Flow__Group_11_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop95;
-                }
-            } while (true);
-
-             after(grammarAccess.getFlowAccess().getGroup_11_4_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4__1__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4_1__0"
-    // InternalTestgeneratorDSL.g:13275:1: rule__Flow__Group_11_4_1__0 : rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1 ;
-    public final void rule__Flow__Group_11_4_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13279:1: ( rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1 )
-            // InternalTestgeneratorDSL.g:13280:2: rule__Flow__Group_11_4_1__0__Impl rule__Flow__Group_11_4_1__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Flow__Group_11_4_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11_4_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4_1__0"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:13287:1: rule__Flow__Group_11_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__Flow__Group_11_4_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13291:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:13292:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:13292:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:13293:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4_1__0__Impl"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4_1__1"
-    // InternalTestgeneratorDSL.g:13302:1: rule__Flow__Group_11_4_1__1 : rule__Flow__Group_11_4_1__1__Impl ;
-    public final void rule__Flow__Group_11_4_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13306:1: ( rule__Flow__Group_11_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:13307:2: rule__Flow__Group_11_4_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__Group_11_4_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4_1__1"
-
-
-    // $ANTLR start "rule__Flow__Group_11_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:13313:1: rule__Flow__Group_11_4_1__1__Impl : ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) ) ;
-    public final void rule__Flow__Group_11_4_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13317:1: ( ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:13318:1: ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:13318:1: ( ( rule__Flow__ExclElementsAssignment_11_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:13319:2: ( rule__Flow__ExclElementsAssignment_11_4_1_1 )
-            {
-             before(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); 
-            // InternalTestgeneratorDSL.g:13320:2: ( rule__Flow__ExclElementsAssignment_11_4_1_1 )
-            // InternalTestgeneratorDSL.g:13320:3: rule__Flow__ExclElementsAssignment_11_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Flow__ExclElementsAssignment_11_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getFlowAccess().getExclElementsAssignment_11_4_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Flow__Group_11_4_1__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__0"
-    // InternalTestgeneratorDSL.g:13329:1: rule__Test__Group__0 : rule__Test__Group__0__Impl rule__Test__Group__1 ;
-    public final void rule__Test__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13333:1: ( rule__Test__Group__0__Impl rule__Test__Group__1 )
-            // InternalTestgeneratorDSL.g:13334:2: rule__Test__Group__0__Impl rule__Test__Group__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Test__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__0"
-
-
-    // $ANTLR start "rule__Test__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:13341:1: rule__Test__Group__0__Impl : ( 'Test' ) ;
-    public final void rule__Test__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13345:1: ( ( 'Test' ) )
-            // InternalTestgeneratorDSL.g:13346:1: ( 'Test' )
-            {
-            // InternalTestgeneratorDSL.g:13346:1: ( 'Test' )
-            // InternalTestgeneratorDSL.g:13347:2: 'Test'
-            {
-             before(grammarAccess.getTestAccess().getTestKeyword_0()); 
-            match(input,73,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getTestKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__1"
-    // InternalTestgeneratorDSL.g:13356:1: rule__Test__Group__1 : rule__Test__Group__1__Impl rule__Test__Group__2 ;
-    public final void rule__Test__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13360:1: ( rule__Test__Group__1__Impl rule__Test__Group__2 )
-            // InternalTestgeneratorDSL.g:13361:2: rule__Test__Group__1__Impl rule__Test__Group__2
-            {
-            pushFollow(FOLLOW_53);
-            rule__Test__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__1"
-
-
-    // $ANTLR start "rule__Test__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:13368:1: rule__Test__Group__1__Impl : ( ( rule__Test__NameAssignment_1 ) ) ;
-    public final void rule__Test__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13372:1: ( ( ( rule__Test__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:13373:1: ( ( rule__Test__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:13373:1: ( ( rule__Test__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:13374:2: ( rule__Test__NameAssignment_1 )
-            {
-             before(grammarAccess.getTestAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:13375:2: ( rule__Test__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:13375:3: rule__Test__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getNameAssignment_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__2"
-    // InternalTestgeneratorDSL.g:13383:1: rule__Test__Group__2 : rule__Test__Group__2__Impl rule__Test__Group__3 ;
-    public final void rule__Test__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13387:1: ( rule__Test__Group__2__Impl rule__Test__Group__3 )
-            // InternalTestgeneratorDSL.g:13388:2: rule__Test__Group__2__Impl rule__Test__Group__3
-            {
-            pushFollow(FOLLOW_4);
-            rule__Test__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__2"
-
-
-    // $ANTLR start "rule__Test__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:13395:1: rule__Test__Group__2__Impl : ( 'for' ) ;
-    public final void rule__Test__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13399:1: ( ( 'for' ) )
-            // InternalTestgeneratorDSL.g:13400:1: ( 'for' )
-            {
-            // InternalTestgeneratorDSL.g:13400:1: ( 'for' )
-            // InternalTestgeneratorDSL.g:13401:2: 'for'
-            {
-             before(grammarAccess.getTestAccess().getForKeyword_2()); 
-            match(input,69,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getForKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__2__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__3"
-    // InternalTestgeneratorDSL.g:13410:1: rule__Test__Group__3 : rule__Test__Group__3__Impl rule__Test__Group__4 ;
-    public final void rule__Test__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13414:1: ( rule__Test__Group__3__Impl rule__Test__Group__4 )
-            // InternalTestgeneratorDSL.g:13415:2: rule__Test__Group__3__Impl rule__Test__Group__4
-            {
-            pushFollow(FOLLOW_10);
-            rule__Test__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__3"
-
-
-    // $ANTLR start "rule__Test__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:13422:1: rule__Test__Group__3__Impl : ( ( rule__Test__FlowReferenceAssignment_3 ) ) ;
-    public final void rule__Test__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13426:1: ( ( ( rule__Test__FlowReferenceAssignment_3 ) ) )
-            // InternalTestgeneratorDSL.g:13427:1: ( ( rule__Test__FlowReferenceAssignment_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:13427:1: ( ( rule__Test__FlowReferenceAssignment_3 ) )
-            // InternalTestgeneratorDSL.g:13428:2: ( rule__Test__FlowReferenceAssignment_3 )
-            {
-             before(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); 
-            // InternalTestgeneratorDSL.g:13429:2: ( rule__Test__FlowReferenceAssignment_3 )
-            // InternalTestgeneratorDSL.g:13429:3: rule__Test__FlowReferenceAssignment_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__FlowReferenceAssignment_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getFlowReferenceAssignment_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__3__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__4"
-    // InternalTestgeneratorDSL.g:13437:1: rule__Test__Group__4 : rule__Test__Group__4__Impl rule__Test__Group__5 ;
-    public final void rule__Test__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13441:1: ( rule__Test__Group__4__Impl rule__Test__Group__5 )
-            // InternalTestgeneratorDSL.g:13442:2: rule__Test__Group__4__Impl rule__Test__Group__5
-            {
-            pushFollow(FOLLOW_10);
-            rule__Test__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__4"
-
-
-    // $ANTLR start "rule__Test__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:13449:1: rule__Test__Group__4__Impl : ( ( rule__Test__Group_4__0 )? ) ;
-    public final void rule__Test__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13453:1: ( ( ( rule__Test__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:13454:1: ( ( rule__Test__Group_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:13454:1: ( ( rule__Test__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:13455:2: ( rule__Test__Group_4__0 )?
-            {
-             before(grammarAccess.getTestAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:13456:2: ( rule__Test__Group_4__0 )?
-            int alt96=2;
-            int LA96_0 = input.LA(1);
-
-            if ( (LA96_0==28) ) {
-                int LA96_1 = input.LA(2);
-
-                if ( (LA96_1==74) ) {
-                    alt96=1;
-                }
-            }
-            switch (alt96) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13456:3: rule__Test__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Test__Group_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getTestAccess().getGroup_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__4__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__5"
-    // InternalTestgeneratorDSL.g:13464:1: rule__Test__Group__5 : rule__Test__Group__5__Impl rule__Test__Group__6 ;
-    public final void rule__Test__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13468:1: ( rule__Test__Group__5__Impl rule__Test__Group__6 )
-            // InternalTestgeneratorDSL.g:13469:2: rule__Test__Group__5__Impl rule__Test__Group__6
-            {
-            pushFollow(FOLLOW_10);
-            rule__Test__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__5"
-
-
-    // $ANTLR start "rule__Test__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:13476:1: rule__Test__Group__5__Impl : ( ( rule__Test__Group_5__0 )? ) ;
-    public final void rule__Test__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13480:1: ( ( ( rule__Test__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:13481:1: ( ( rule__Test__Group_5__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:13481:1: ( ( rule__Test__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:13482:2: ( rule__Test__Group_5__0 )?
-            {
-             before(grammarAccess.getTestAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:13483:2: ( rule__Test__Group_5__0 )?
-            int alt97=2;
-            int LA97_0 = input.LA(1);
-
-            if ( (LA97_0==28) ) {
-                int LA97_1 = input.LA(2);
-
-                if ( (LA97_1==76) ) {
-                    alt97=1;
-                }
-            }
-            switch (alt97) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13483:3: rule__Test__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Test__Group_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getTestAccess().getGroup_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__5__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__6"
-    // InternalTestgeneratorDSL.g:13491:1: rule__Test__Group__6 : rule__Test__Group__6__Impl rule__Test__Group__7 ;
-    public final void rule__Test__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13495:1: ( rule__Test__Group__6__Impl rule__Test__Group__7 )
-            // InternalTestgeneratorDSL.g:13496:2: rule__Test__Group__6__Impl rule__Test__Group__7
-            {
-            pushFollow(FOLLOW_10);
-            rule__Test__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__6"
-
-
-    // $ANTLR start "rule__Test__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:13503:1: rule__Test__Group__6__Impl : ( ( rule__Test__EndCheckAssignment_6 )? ) ;
-    public final void rule__Test__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13507:1: ( ( ( rule__Test__EndCheckAssignment_6 )? ) )
-            // InternalTestgeneratorDSL.g:13508:1: ( ( rule__Test__EndCheckAssignment_6 )? )
-            {
-            // InternalTestgeneratorDSL.g:13508:1: ( ( rule__Test__EndCheckAssignment_6 )? )
-            // InternalTestgeneratorDSL.g:13509:2: ( rule__Test__EndCheckAssignment_6 )?
-            {
-             before(grammarAccess.getTestAccess().getEndCheckAssignment_6()); 
-            // InternalTestgeneratorDSL.g:13510:2: ( rule__Test__EndCheckAssignment_6 )?
-            int alt98=2;
-            int LA98_0 = input.LA(1);
-
-            if ( (LA98_0==28) ) {
-                int LA98_1 = input.LA(2);
-
-                if ( (LA98_1==77) ) {
-                    alt98=1;
-                }
-            }
-            switch (alt98) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13510:3: rule__Test__EndCheckAssignment_6
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Test__EndCheckAssignment_6();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getTestAccess().getEndCheckAssignment_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__6__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__7"
-    // InternalTestgeneratorDSL.g:13518:1: rule__Test__Group__7 : rule__Test__Group__7__Impl rule__Test__Group__8 ;
-    public final void rule__Test__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13522:1: ( rule__Test__Group__7__Impl rule__Test__Group__8 )
-            // InternalTestgeneratorDSL.g:13523:2: rule__Test__Group__7__Impl rule__Test__Group__8
-            {
-            pushFollow(FOLLOW_10);
-            rule__Test__Group__7__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__8();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__7"
-
-
-    // $ANTLR start "rule__Test__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:13530:1: rule__Test__Group__7__Impl : ( ( rule__Test__Group_7__0 )? ) ;
-    public final void rule__Test__Group__7__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13534:1: ( ( ( rule__Test__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:13535:1: ( ( rule__Test__Group_7__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:13535:1: ( ( rule__Test__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:13536:2: ( rule__Test__Group_7__0 )?
-            {
-             before(grammarAccess.getTestAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:13537:2: ( rule__Test__Group_7__0 )?
-            int alt99=2;
-            int LA99_0 = input.LA(1);
-
-            if ( (LA99_0==28) ) {
-                alt99=1;
-            }
-            switch (alt99) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13537:3: rule__Test__Group_7__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Test__Group_7__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getTestAccess().getGroup_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__7__Impl"
-
-
-    // $ANTLR start "rule__Test__Group__8"
-    // InternalTestgeneratorDSL.g:13545:1: rule__Test__Group__8 : rule__Test__Group__8__Impl ;
-    public final void rule__Test__Group__8() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13549:1: ( rule__Test__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:13550:2: rule__Test__Group__8__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group__8__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__8"
-
-
-    // $ANTLR start "rule__Test__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:13556:1: rule__Test__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__Test__Group__8__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13560:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:13561:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:13561:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:13562:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group__8__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_4__0"
-    // InternalTestgeneratorDSL.g:13572:1: rule__Test__Group_4__0 : rule__Test__Group_4__0__Impl rule__Test__Group_4__1 ;
-    public final void rule__Test__Group_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13576:1: ( rule__Test__Group_4__0__Impl rule__Test__Group_4__1 )
-            // InternalTestgeneratorDSL.g:13577:2: rule__Test__Group_4__0__Impl rule__Test__Group_4__1
-            {
-            pushFollow(FOLLOW_58);
-            rule__Test__Group_4__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_4__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__0"
-
-
-    // $ANTLR start "rule__Test__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:13584:1: rule__Test__Group_4__0__Impl : ( 'with' ) ;
-    public final void rule__Test__Group_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13588:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:13589:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:13589:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:13590:2: 'with'
-            {
-             before(grammarAccess.getTestAccess().getWithKeyword_4_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getWithKeyword_4_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_4__1"
-    // InternalTestgeneratorDSL.g:13599:1: rule__Test__Group_4__1 : rule__Test__Group_4__1__Impl rule__Test__Group_4__2 ;
-    public final void rule__Test__Group_4__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13603:1: ( rule__Test__Group_4__1__Impl rule__Test__Group_4__2 )
-            // InternalTestgeneratorDSL.g:13604:2: rule__Test__Group_4__1__Impl rule__Test__Group_4__2
-            {
-            pushFollow(FOLLOW_43);
-            rule__Test__Group_4__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_4__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__1"
-
-
-    // $ANTLR start "rule__Test__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:13611:1: rule__Test__Group_4__1__Impl : ( 'priority' ) ;
-    public final void rule__Test__Group_4__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13615:1: ( ( 'priority' ) )
-            // InternalTestgeneratorDSL.g:13616:1: ( 'priority' )
-            {
-            // InternalTestgeneratorDSL.g:13616:1: ( 'priority' )
-            // InternalTestgeneratorDSL.g:13617:2: 'priority'
-            {
-             before(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); 
-            match(input,74,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getPriorityKeyword_4_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_4__2"
-    // InternalTestgeneratorDSL.g:13626:1: rule__Test__Group_4__2 : rule__Test__Group_4__2__Impl ;
-    public final void rule__Test__Group_4__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13630:1: ( rule__Test__Group_4__2__Impl )
-            // InternalTestgeneratorDSL.g:13631:2: rule__Test__Group_4__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_4__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__2"
-
-
-    // $ANTLR start "rule__Test__Group_4__2__Impl"
-    // InternalTestgeneratorDSL.g:13637:1: rule__Test__Group_4__2__Impl : ( ( rule__Test__PriorityAssignment_4_2 ) ) ;
-    public final void rule__Test__Group_4__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13641:1: ( ( ( rule__Test__PriorityAssignment_4_2 ) ) )
-            // InternalTestgeneratorDSL.g:13642:1: ( ( rule__Test__PriorityAssignment_4_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:13642:1: ( ( rule__Test__PriorityAssignment_4_2 ) )
-            // InternalTestgeneratorDSL.g:13643:2: ( rule__Test__PriorityAssignment_4_2 )
-            {
-             before(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); 
-            // InternalTestgeneratorDSL.g:13644:2: ( rule__Test__PriorityAssignment_4_2 )
-            // InternalTestgeneratorDSL.g:13644:3: rule__Test__PriorityAssignment_4_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__PriorityAssignment_4_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getPriorityAssignment_4_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_4__2__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_5__0"
-    // InternalTestgeneratorDSL.g:13653:1: rule__Test__Group_5__0 : rule__Test__Group_5__0__Impl rule__Test__Group_5__1 ;
-    public final void rule__Test__Group_5__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13657:1: ( rule__Test__Group_5__0__Impl rule__Test__Group_5__1 )
-            // InternalTestgeneratorDSL.g:13658:2: rule__Test__Group_5__0__Impl rule__Test__Group_5__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__Test__Group_5__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_5__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5__0"
-
-
-    // $ANTLR start "rule__Test__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:13665:1: rule__Test__Group_5__0__Impl : ( ( rule__Test__DeclarationsAssignment_5_0 ) ) ;
-    public final void rule__Test__Group_5__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13669:1: ( ( ( rule__Test__DeclarationsAssignment_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:13670:1: ( ( rule__Test__DeclarationsAssignment_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:13670:1: ( ( rule__Test__DeclarationsAssignment_5_0 ) )
-            // InternalTestgeneratorDSL.g:13671:2: ( rule__Test__DeclarationsAssignment_5_0 )
-            {
-             before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); 
-            // InternalTestgeneratorDSL.g:13672:2: ( rule__Test__DeclarationsAssignment_5_0 )
-            // InternalTestgeneratorDSL.g:13672:3: rule__Test__DeclarationsAssignment_5_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__DeclarationsAssignment_5_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_5__1"
-    // InternalTestgeneratorDSL.g:13680:1: rule__Test__Group_5__1 : rule__Test__Group_5__1__Impl ;
-    public final void rule__Test__Group_5__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13684:1: ( rule__Test__Group_5__1__Impl )
-            // InternalTestgeneratorDSL.g:13685:2: rule__Test__Group_5__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_5__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5__1"
-
-
-    // $ANTLR start "rule__Test__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:13691:1: rule__Test__Group_5__1__Impl : ( ( rule__Test__Group_5_1__0 )* ) ;
-    public final void rule__Test__Group_5__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13695:1: ( ( ( rule__Test__Group_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:13696:1: ( ( rule__Test__Group_5_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:13696:1: ( ( rule__Test__Group_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:13697:2: ( rule__Test__Group_5_1__0 )*
-            {
-             before(grammarAccess.getTestAccess().getGroup_5_1()); 
-            // InternalTestgeneratorDSL.g:13698:2: ( rule__Test__Group_5_1__0 )*
-            loop100:
-            do {
-                int alt100=2;
-                int LA100_0 = input.LA(1);
-
-                if ( (LA100_0==RULE_SEPARATOR) ) {
-                    alt100=1;
-                }
-
-
-                switch (alt100) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:13698:3: rule__Test__Group_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__Test__Group_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop100;
-                }
-            } while (true);
-
-             after(grammarAccess.getTestAccess().getGroup_5_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_5_1__0"
-    // InternalTestgeneratorDSL.g:13707:1: rule__Test__Group_5_1__0 : rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1 ;
-    public final void rule__Test__Group_5_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13711:1: ( rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1 )
-            // InternalTestgeneratorDSL.g:13712:2: rule__Test__Group_5_1__0__Impl rule__Test__Group_5_1__1
-            {
-            pushFollow(FOLLOW_5);
-            rule__Test__Group_5_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_5_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5_1__0"
-
-
-    // $ANTLR start "rule__Test__Group_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:13719:1: rule__Test__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__Test__Group_5_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13723:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:13724:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:13724:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:13725:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5_1__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_5_1__1"
-    // InternalTestgeneratorDSL.g:13734:1: rule__Test__Group_5_1__1 : rule__Test__Group_5_1__1__Impl ;
-    public final void rule__Test__Group_5_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13738:1: ( rule__Test__Group_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:13739:2: rule__Test__Group_5_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_5_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5_1__1"
-
-
-    // $ANTLR start "rule__Test__Group_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:13745:1: rule__Test__Group_5_1__1__Impl : ( ( rule__Test__DeclarationsAssignment_5_1_1 ) ) ;
-    public final void rule__Test__Group_5_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13749:1: ( ( ( rule__Test__DeclarationsAssignment_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:13750:1: ( ( rule__Test__DeclarationsAssignment_5_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:13750:1: ( ( rule__Test__DeclarationsAssignment_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:13751:2: ( rule__Test__DeclarationsAssignment_5_1_1 )
-            {
-             before(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); 
-            // InternalTestgeneratorDSL.g:13752:2: ( rule__Test__DeclarationsAssignment_5_1_1 )
-            // InternalTestgeneratorDSL.g:13752:3: rule__Test__DeclarationsAssignment_5_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__DeclarationsAssignment_5_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getDeclarationsAssignment_5_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_5_1__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__0"
-    // InternalTestgeneratorDSL.g:13761:1: rule__Test__Group_7__0 : rule__Test__Group_7__0__Impl rule__Test__Group_7__1 ;
-    public final void rule__Test__Group_7__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13765:1: ( rule__Test__Group_7__0__Impl rule__Test__Group_7__1 )
-            // InternalTestgeneratorDSL.g:13766:2: rule__Test__Group_7__0__Impl rule__Test__Group_7__1
-            {
-            pushFollow(FOLLOW_59);
-            rule__Test__Group_7__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__0"
-
-
-    // $ANTLR start "rule__Test__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:13773:1: rule__Test__Group_7__0__Impl : ( 'with' ) ;
-    public final void rule__Test__Group_7__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13777:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:13778:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:13778:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:13779:2: 'with'
-            {
-             before(grammarAccess.getTestAccess().getWithKeyword_7_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getWithKeyword_7_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__1"
-    // InternalTestgeneratorDSL.g:13788:1: rule__Test__Group_7__1 : rule__Test__Group_7__1__Impl rule__Test__Group_7__2 ;
-    public final void rule__Test__Group_7__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13792:1: ( rule__Test__Group_7__1__Impl rule__Test__Group_7__2 )
-            // InternalTestgeneratorDSL.g:13793:2: rule__Test__Group_7__1__Impl rule__Test__Group_7__2
-            {
-            pushFollow(FOLLOW_12);
-            rule__Test__Group_7__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__1"
-
-
-    // $ANTLR start "rule__Test__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:13800:1: rule__Test__Group_7__1__Impl : ( 'mocks' ) ;
-    public final void rule__Test__Group_7__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13804:1: ( ( 'mocks' ) )
-            // InternalTestgeneratorDSL.g:13805:1: ( 'mocks' )
-            {
-            // InternalTestgeneratorDSL.g:13805:1: ( 'mocks' )
-            // InternalTestgeneratorDSL.g:13806:2: 'mocks'
-            {
-             before(grammarAccess.getTestAccess().getMocksKeyword_7_1()); 
-            match(input,75,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getMocksKeyword_7_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__2"
-    // InternalTestgeneratorDSL.g:13815:1: rule__Test__Group_7__2 : rule__Test__Group_7__2__Impl rule__Test__Group_7__3 ;
-    public final void rule__Test__Group_7__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13819:1: ( rule__Test__Group_7__2__Impl rule__Test__Group_7__3 )
-            // InternalTestgeneratorDSL.g:13820:2: rule__Test__Group_7__2__Impl rule__Test__Group_7__3
-            {
-            pushFollow(FOLLOW_13);
-            rule__Test__Group_7__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__2"
-
-
-    // $ANTLR start "rule__Test__Group_7__2__Impl"
-    // InternalTestgeneratorDSL.g:13827:1: rule__Test__Group_7__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__Test__Group_7__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13831:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:13832:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:13832:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:13833:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__2__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__3"
-    // InternalTestgeneratorDSL.g:13842:1: rule__Test__Group_7__3 : rule__Test__Group_7__3__Impl rule__Test__Group_7__4 ;
-    public final void rule__Test__Group_7__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13846:1: ( rule__Test__Group_7__3__Impl rule__Test__Group_7__4 )
-            // InternalTestgeneratorDSL.g:13847:2: rule__Test__Group_7__3__Impl rule__Test__Group_7__4
-            {
-            pushFollow(FOLLOW_21);
-            rule__Test__Group_7__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__3"
-
-
-    // $ANTLR start "rule__Test__Group_7__3__Impl"
-    // InternalTestgeneratorDSL.g:13854:1: rule__Test__Group_7__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__Test__Group_7__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13858:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:13859:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:13859:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:13860:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__3__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__4"
-    // InternalTestgeneratorDSL.g:13869:1: rule__Test__Group_7__4 : rule__Test__Group_7__4__Impl rule__Test__Group_7__5 ;
-    public final void rule__Test__Group_7__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13873:1: ( rule__Test__Group_7__4__Impl rule__Test__Group_7__5 )
-            // InternalTestgeneratorDSL.g:13874:2: rule__Test__Group_7__4__Impl rule__Test__Group_7__5
-            {
-            pushFollow(FOLLOW_21);
-            rule__Test__Group_7__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__4"
-
-
-    // $ANTLR start "rule__Test__Group_7__4__Impl"
-    // InternalTestgeneratorDSL.g:13881:1: rule__Test__Group_7__4__Impl : ( ( rule__Test__Group_7_4__0 )? ) ;
-    public final void rule__Test__Group_7__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13885:1: ( ( ( rule__Test__Group_7_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:13886:1: ( ( rule__Test__Group_7_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:13886:1: ( ( rule__Test__Group_7_4__0 )? )
-            // InternalTestgeneratorDSL.g:13887:2: ( rule__Test__Group_7_4__0 )?
-            {
-             before(grammarAccess.getTestAccess().getGroup_7_4()); 
-            // InternalTestgeneratorDSL.g:13888:2: ( rule__Test__Group_7_4__0 )?
-            int alt101=2;
-            int LA101_0 = input.LA(1);
-
-            if ( (LA101_0==RULE_ID) ) {
-                alt101=1;
-            }
-            switch (alt101) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:13888:3: rule__Test__Group_7_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__Test__Group_7_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getTestAccess().getGroup_7_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__4__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7__5"
-    // InternalTestgeneratorDSL.g:13896:1: rule__Test__Group_7__5 : rule__Test__Group_7__5__Impl ;
-    public final void rule__Test__Group_7__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13900:1: ( rule__Test__Group_7__5__Impl )
-            // InternalTestgeneratorDSL.g:13901:2: rule__Test__Group_7__5__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7__5__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__5"
-
-
-    // $ANTLR start "rule__Test__Group_7__5__Impl"
-    // InternalTestgeneratorDSL.g:13907:1: rule__Test__Group_7__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__Test__Group_7__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13911:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:13912:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:13912:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:13913:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getLIST_CLOSEDTerminalRuleCall_7_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7__5__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7_4__0"
-    // InternalTestgeneratorDSL.g:13923:1: rule__Test__Group_7_4__0 : rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1 ;
-    public final void rule__Test__Group_7_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13927:1: ( rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1 )
-            // InternalTestgeneratorDSL.g:13928:2: rule__Test__Group_7_4__0__Impl rule__Test__Group_7_4__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__Test__Group_7_4__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7_4__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4__0"
-
-
-    // $ANTLR start "rule__Test__Group_7_4__0__Impl"
-    // InternalTestgeneratorDSL.g:13935:1: rule__Test__Group_7_4__0__Impl : ( ( rule__Test__MocksAssignment_7_4_0 ) ) ;
-    public final void rule__Test__Group_7_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13939:1: ( ( ( rule__Test__MocksAssignment_7_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:13940:1: ( ( rule__Test__MocksAssignment_7_4_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:13940:1: ( ( rule__Test__MocksAssignment_7_4_0 ) )
-            // InternalTestgeneratorDSL.g:13941:2: ( rule__Test__MocksAssignment_7_4_0 )
-            {
-             before(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); 
-            // InternalTestgeneratorDSL.g:13942:2: ( rule__Test__MocksAssignment_7_4_0 )
-            // InternalTestgeneratorDSL.g:13942:3: rule__Test__MocksAssignment_7_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__MocksAssignment_7_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getMocksAssignment_7_4_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7_4__1"
-    // InternalTestgeneratorDSL.g:13950:1: rule__Test__Group_7_4__1 : rule__Test__Group_7_4__1__Impl ;
-    public final void rule__Test__Group_7_4__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13954:1: ( rule__Test__Group_7_4__1__Impl )
-            // InternalTestgeneratorDSL.g:13955:2: rule__Test__Group_7_4__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7_4__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4__1"
-
-
-    // $ANTLR start "rule__Test__Group_7_4__1__Impl"
-    // InternalTestgeneratorDSL.g:13961:1: rule__Test__Group_7_4__1__Impl : ( ( rule__Test__Group_7_4_1__0 )* ) ;
-    public final void rule__Test__Group_7_4__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13965:1: ( ( ( rule__Test__Group_7_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:13966:1: ( ( rule__Test__Group_7_4_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:13966:1: ( ( rule__Test__Group_7_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:13967:2: ( rule__Test__Group_7_4_1__0 )*
-            {
-             before(grammarAccess.getTestAccess().getGroup_7_4_1()); 
-            // InternalTestgeneratorDSL.g:13968:2: ( rule__Test__Group_7_4_1__0 )*
-            loop102:
-            do {
-                int alt102=2;
-                int LA102_0 = input.LA(1);
-
-                if ( (LA102_0==RULE_SEPARATOR) ) {
-                    alt102=1;
-                }
-
-
-                switch (alt102) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:13968:3: rule__Test__Group_7_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__Test__Group_7_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop102;
-                }
-            } while (true);
-
-             after(grammarAccess.getTestAccess().getGroup_7_4_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4__1__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7_4_1__0"
-    // InternalTestgeneratorDSL.g:13977:1: rule__Test__Group_7_4_1__0 : rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1 ;
-    public final void rule__Test__Group_7_4_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13981:1: ( rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1 )
-            // InternalTestgeneratorDSL.g:13982:2: rule__Test__Group_7_4_1__0__Impl rule__Test__Group_7_4_1__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__Test__Group_7_4_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7_4_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4_1__0"
-
-
-    // $ANTLR start "rule__Test__Group_7_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:13989:1: rule__Test__Group_7_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__Test__Group_7_4_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:13993:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:13994:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:13994:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:13995:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4_1__0__Impl"
-
-
-    // $ANTLR start "rule__Test__Group_7_4_1__1"
-    // InternalTestgeneratorDSL.g:14004:1: rule__Test__Group_7_4_1__1 : rule__Test__Group_7_4_1__1__Impl ;
-    public final void rule__Test__Group_7_4_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14008:1: ( rule__Test__Group_7_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:14009:2: rule__Test__Group_7_4_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__Group_7_4_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4_1__1"
-
-
-    // $ANTLR start "rule__Test__Group_7_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:14015:1: rule__Test__Group_7_4_1__1__Impl : ( ( rule__Test__MocksAssignment_7_4_1_1 ) ) ;
-    public final void rule__Test__Group_7_4_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14019:1: ( ( ( rule__Test__MocksAssignment_7_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:14020:1: ( ( rule__Test__MocksAssignment_7_4_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:14020:1: ( ( rule__Test__MocksAssignment_7_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:14021:2: ( rule__Test__MocksAssignment_7_4_1_1 )
-            {
-             before(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); 
-            // InternalTestgeneratorDSL.g:14022:2: ( rule__Test__MocksAssignment_7_4_1_1 )
-            // InternalTestgeneratorDSL.g:14022:3: rule__Test__MocksAssignment_7_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__Test__MocksAssignment_7_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getTestAccess().getMocksAssignment_7_4_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__Test__Group_7_4_1__1__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__0"
-    // InternalTestgeneratorDSL.g:14031:1: rule__VariableDeclarations__Group__0 : rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1 ;
-    public final void rule__VariableDeclarations__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14035:1: ( rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1 )
-            // InternalTestgeneratorDSL.g:14036:2: rule__VariableDeclarations__Group__0__Impl rule__VariableDeclarations__Group__1
-            {
-            pushFollow(FOLLOW_60);
-            rule__VariableDeclarations__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__0"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14043:1: rule__VariableDeclarations__Group__0__Impl : ( 'with' ) ;
-    public final void rule__VariableDeclarations__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14047:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:14048:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:14048:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:14049:2: 'with'
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__0__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__1"
-    // InternalTestgeneratorDSL.g:14058:1: rule__VariableDeclarations__Group__1 : rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2 ;
-    public final void rule__VariableDeclarations__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14062:1: ( rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2 )
-            // InternalTestgeneratorDSL.g:14063:2: rule__VariableDeclarations__Group__1__Impl rule__VariableDeclarations__Group__2
-            {
-            pushFollow(FOLLOW_53);
-            rule__VariableDeclarations__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__1"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14070:1: rule__VariableDeclarations__Group__1__Impl : ( 'variables' ) ;
-    public final void rule__VariableDeclarations__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14074:1: ( ( 'variables' ) )
-            // InternalTestgeneratorDSL.g:14075:1: ( 'variables' )
-            {
-            // InternalTestgeneratorDSL.g:14075:1: ( 'variables' )
-            // InternalTestgeneratorDSL.g:14076:2: 'variables'
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); 
-            match(input,76,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__1__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__2"
-    // InternalTestgeneratorDSL.g:14085:1: rule__VariableDeclarations__Group__2 : rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3 ;
-    public final void rule__VariableDeclarations__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14089:1: ( rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3 )
-            // InternalTestgeneratorDSL.g:14090:2: rule__VariableDeclarations__Group__2__Impl rule__VariableDeclarations__Group__3
-            {
-            pushFollow(FOLLOW_4);
-            rule__VariableDeclarations__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__2"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14097:1: rule__VariableDeclarations__Group__2__Impl : ( 'for' ) ;
-    public final void rule__VariableDeclarations__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14101:1: ( ( 'for' ) )
-            // InternalTestgeneratorDSL.g:14102:1: ( 'for' )
-            {
-            // InternalTestgeneratorDSL.g:14102:1: ( 'for' )
-            // InternalTestgeneratorDSL.g:14103:2: 'for'
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); 
-            match(input,69,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getForKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__2__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__3"
-    // InternalTestgeneratorDSL.g:14112:1: rule__VariableDeclarations__Group__3 : rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4 ;
-    public final void rule__VariableDeclarations__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14116:1: ( rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4 )
-            // InternalTestgeneratorDSL.g:14117:2: rule__VariableDeclarations__Group__3__Impl rule__VariableDeclarations__Group__4
-            {
-            pushFollow(FOLLOW_12);
-            rule__VariableDeclarations__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__3"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:14124:1: rule__VariableDeclarations__Group__3__Impl : ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) ) ;
-    public final void rule__VariableDeclarations__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14128:1: ( ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) ) )
-            // InternalTestgeneratorDSL.g:14129:1: ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:14129:1: ( ( rule__VariableDeclarations__TaskReferenceAssignment_3 ) )
-            // InternalTestgeneratorDSL.g:14130:2: ( rule__VariableDeclarations__TaskReferenceAssignment_3 )
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); 
-            // InternalTestgeneratorDSL.g:14131:2: ( rule__VariableDeclarations__TaskReferenceAssignment_3 )
-            // InternalTestgeneratorDSL.g:14131:3: rule__VariableDeclarations__TaskReferenceAssignment_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__TaskReferenceAssignment_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceAssignment_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__3__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__4"
-    // InternalTestgeneratorDSL.g:14139:1: rule__VariableDeclarations__Group__4 : rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5 ;
-    public final void rule__VariableDeclarations__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14143:1: ( rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5 )
-            // InternalTestgeneratorDSL.g:14144:2: rule__VariableDeclarations__Group__4__Impl rule__VariableDeclarations__Group__5
-            {
-            pushFollow(FOLLOW_13);
-            rule__VariableDeclarations__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__4"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:14151:1: rule__VariableDeclarations__Group__4__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__VariableDeclarations__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14155:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:14156:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:14156:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:14157:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__4__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__5"
-    // InternalTestgeneratorDSL.g:14166:1: rule__VariableDeclarations__Group__5 : rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6 ;
-    public final void rule__VariableDeclarations__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14170:1: ( rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6 )
-            // InternalTestgeneratorDSL.g:14171:2: rule__VariableDeclarations__Group__5__Impl rule__VariableDeclarations__Group__6
-            {
-            pushFollow(FOLLOW_21);
-            rule__VariableDeclarations__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__5"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:14178:1: rule__VariableDeclarations__Group__5__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__VariableDeclarations__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14182:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:14183:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:14183:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:14184:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__5__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__6"
-    // InternalTestgeneratorDSL.g:14193:1: rule__VariableDeclarations__Group__6 : rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7 ;
-    public final void rule__VariableDeclarations__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14197:1: ( rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7 )
-            // InternalTestgeneratorDSL.g:14198:2: rule__VariableDeclarations__Group__6__Impl rule__VariableDeclarations__Group__7
-            {
-            pushFollow(FOLLOW_21);
-            rule__VariableDeclarations__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__6"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:14205:1: rule__VariableDeclarations__Group__6__Impl : ( ( rule__VariableDeclarations__Group_6__0 )? ) ;
-    public final void rule__VariableDeclarations__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14209:1: ( ( ( rule__VariableDeclarations__Group_6__0 )? ) )
-            // InternalTestgeneratorDSL.g:14210:1: ( ( rule__VariableDeclarations__Group_6__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:14210:1: ( ( rule__VariableDeclarations__Group_6__0 )? )
-            // InternalTestgeneratorDSL.g:14211:2: ( rule__VariableDeclarations__Group_6__0 )?
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); 
-            // InternalTestgeneratorDSL.g:14212:2: ( rule__VariableDeclarations__Group_6__0 )?
-            int alt103=2;
-            int LA103_0 = input.LA(1);
-
-            if ( (LA103_0==RULE_ID) ) {
-                alt103=1;
-            }
-            switch (alt103) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:14212:3: rule__VariableDeclarations__Group_6__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__VariableDeclarations__Group_6__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getVariableDeclarationsAccess().getGroup_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__6__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__7"
-    // InternalTestgeneratorDSL.g:14220:1: rule__VariableDeclarations__Group__7 : rule__VariableDeclarations__Group__7__Impl ;
-    public final void rule__VariableDeclarations__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14224:1: ( rule__VariableDeclarations__Group__7__Impl )
-            // InternalTestgeneratorDSL.g:14225:2: rule__VariableDeclarations__Group__7__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group__7__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__7"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:14231:1: rule__VariableDeclarations__Group__7__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__VariableDeclarations__Group__7__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14235:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:14236:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:14236:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:14237:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getLIST_CLOSEDTerminalRuleCall_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group__7__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6__0"
-    // InternalTestgeneratorDSL.g:14247:1: rule__VariableDeclarations__Group_6__0 : rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1 ;
-    public final void rule__VariableDeclarations__Group_6__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14251:1: ( rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1 )
-            // InternalTestgeneratorDSL.g:14252:2: rule__VariableDeclarations__Group_6__0__Impl rule__VariableDeclarations__Group_6__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__VariableDeclarations__Group_6__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group_6__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6__0"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6__0__Impl"
-    // InternalTestgeneratorDSL.g:14259:1: rule__VariableDeclarations__Group_6__0__Impl : ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) ) ;
-    public final void rule__VariableDeclarations__Group_6__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14263:1: ( ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) ) )
-            // InternalTestgeneratorDSL.g:14264:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14264:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_0 ) )
-            // InternalTestgeneratorDSL.g:14265:2: ( rule__VariableDeclarations__VariablesAssignment_6_0 )
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); 
-            // InternalTestgeneratorDSL.g:14266:2: ( rule__VariableDeclarations__VariablesAssignment_6_0 )
-            // InternalTestgeneratorDSL.g:14266:3: rule__VariableDeclarations__VariablesAssignment_6_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__VariablesAssignment_6_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6__0__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6__1"
-    // InternalTestgeneratorDSL.g:14274:1: rule__VariableDeclarations__Group_6__1 : rule__VariableDeclarations__Group_6__1__Impl ;
-    public final void rule__VariableDeclarations__Group_6__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14278:1: ( rule__VariableDeclarations__Group_6__1__Impl )
-            // InternalTestgeneratorDSL.g:14279:2: rule__VariableDeclarations__Group_6__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group_6__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6__1"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6__1__Impl"
-    // InternalTestgeneratorDSL.g:14285:1: rule__VariableDeclarations__Group_6__1__Impl : ( ( rule__VariableDeclarations__Group_6_1__0 )* ) ;
-    public final void rule__VariableDeclarations__Group_6__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14289:1: ( ( ( rule__VariableDeclarations__Group_6_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:14290:1: ( ( rule__VariableDeclarations__Group_6_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:14290:1: ( ( rule__VariableDeclarations__Group_6_1__0 )* )
-            // InternalTestgeneratorDSL.g:14291:2: ( rule__VariableDeclarations__Group_6_1__0 )*
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); 
-            // InternalTestgeneratorDSL.g:14292:2: ( rule__VariableDeclarations__Group_6_1__0 )*
-            loop104:
-            do {
-                int alt104=2;
-                int LA104_0 = input.LA(1);
-
-                if ( (LA104_0==RULE_SEPARATOR) ) {
-                    alt104=1;
-                }
-
-
-                switch (alt104) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:14292:3: rule__VariableDeclarations__Group_6_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__VariableDeclarations__Group_6_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop104;
-                }
-            } while (true);
-
-             after(grammarAccess.getVariableDeclarationsAccess().getGroup_6_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6__1__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6_1__0"
-    // InternalTestgeneratorDSL.g:14301:1: rule__VariableDeclarations__Group_6_1__0 : rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1 ;
-    public final void rule__VariableDeclarations__Group_6_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14305:1: ( rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1 )
-            // InternalTestgeneratorDSL.g:14306:2: rule__VariableDeclarations__Group_6_1__0__Impl rule__VariableDeclarations__Group_6_1__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__VariableDeclarations__Group_6_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group_6_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6_1__0"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6_1__0__Impl"
-    // InternalTestgeneratorDSL.g:14313:1: rule__VariableDeclarations__Group_6_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__VariableDeclarations__Group_6_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14317:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:14318:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:14318:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:14319:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6_1__0__Impl"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6_1__1"
-    // InternalTestgeneratorDSL.g:14328:1: rule__VariableDeclarations__Group_6_1__1 : rule__VariableDeclarations__Group_6_1__1__Impl ;
-    public final void rule__VariableDeclarations__Group_6_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14332:1: ( rule__VariableDeclarations__Group_6_1__1__Impl )
-            // InternalTestgeneratorDSL.g:14333:2: rule__VariableDeclarations__Group_6_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__Group_6_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6_1__1"
-
-
-    // $ANTLR start "rule__VariableDeclarations__Group_6_1__1__Impl"
-    // InternalTestgeneratorDSL.g:14339:1: rule__VariableDeclarations__Group_6_1__1__Impl : ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) ) ;
-    public final void rule__VariableDeclarations__Group_6_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14343:1: ( ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:14344:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:14344:1: ( ( rule__VariableDeclarations__VariablesAssignment_6_1_1 ) )
-            // InternalTestgeneratorDSL.g:14345:2: ( rule__VariableDeclarations__VariablesAssignment_6_1_1 )
-            {
-             before(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); 
-            // InternalTestgeneratorDSL.g:14346:2: ( rule__VariableDeclarations__VariablesAssignment_6_1_1 )
-            // InternalTestgeneratorDSL.g:14346:3: rule__VariableDeclarations__VariablesAssignment_6_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__VariableDeclarations__VariablesAssignment_6_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getVariableDeclarationsAccess().getVariablesAssignment_6_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__VariableDeclarations__Group_6_1__1__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__0"
-    // InternalTestgeneratorDSL.g:14355:1: rule__EndChecks__Group__0 : rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1 ;
-    public final void rule__EndChecks__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14359:1: ( rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1 )
-            // InternalTestgeneratorDSL.g:14360:2: rule__EndChecks__Group__0__Impl rule__EndChecks__Group__1
-            {
-            pushFollow(FOLLOW_61);
-            rule__EndChecks__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__0"
-
-
-    // $ANTLR start "rule__EndChecks__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14367:1: rule__EndChecks__Group__0__Impl : ( 'with' ) ;
-    public final void rule__EndChecks__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14371:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:14372:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:14372:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:14373:2: 'with'
-            {
-             before(grammarAccess.getEndChecksAccess().getWithKeyword_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getWithKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__0__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__1"
-    // InternalTestgeneratorDSL.g:14382:1: rule__EndChecks__Group__1 : rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2 ;
-    public final void rule__EndChecks__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14386:1: ( rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2 )
-            // InternalTestgeneratorDSL.g:14387:2: rule__EndChecks__Group__1__Impl rule__EndChecks__Group__2
-            {
-            pushFollow(FOLLOW_12);
-            rule__EndChecks__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__1"
-
-
-    // $ANTLR start "rule__EndChecks__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14394:1: rule__EndChecks__Group__1__Impl : ( 'check' ) ;
-    public final void rule__EndChecks__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14398:1: ( ( 'check' ) )
-            // InternalTestgeneratorDSL.g:14399:1: ( 'check' )
-            {
-            // InternalTestgeneratorDSL.g:14399:1: ( 'check' )
-            // InternalTestgeneratorDSL.g:14400:2: 'check'
-            {
-             before(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); 
-            match(input,77,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getCheckKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__1__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__2"
-    // InternalTestgeneratorDSL.g:14409:1: rule__EndChecks__Group__2 : rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3 ;
-    public final void rule__EndChecks__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14413:1: ( rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3 )
-            // InternalTestgeneratorDSL.g:14414:2: rule__EndChecks__Group__2__Impl rule__EndChecks__Group__3
-            {
-            pushFollow(FOLLOW_13);
-            rule__EndChecks__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__2"
-
-
-    // $ANTLR start "rule__EndChecks__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14421:1: rule__EndChecks__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__EndChecks__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14425:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:14426:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:14426:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:14427:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__2__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__3"
-    // InternalTestgeneratorDSL.g:14436:1: rule__EndChecks__Group__3 : rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4 ;
-    public final void rule__EndChecks__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14440:1: ( rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4 )
-            // InternalTestgeneratorDSL.g:14441:2: rule__EndChecks__Group__3__Impl rule__EndChecks__Group__4
-            {
-            pushFollow(FOLLOW_21);
-            rule__EndChecks__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__3"
-
-
-    // $ANTLR start "rule__EndChecks__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:14448:1: rule__EndChecks__Group__3__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__EndChecks__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14452:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:14453:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:14453:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:14454:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__3__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__4"
-    // InternalTestgeneratorDSL.g:14463:1: rule__EndChecks__Group__4 : rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5 ;
-    public final void rule__EndChecks__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14467:1: ( rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5 )
-            // InternalTestgeneratorDSL.g:14468:2: rule__EndChecks__Group__4__Impl rule__EndChecks__Group__5
-            {
-            pushFollow(FOLLOW_21);
-            rule__EndChecks__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__4"
-
-
-    // $ANTLR start "rule__EndChecks__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:14475:1: rule__EndChecks__Group__4__Impl : ( ( rule__EndChecks__Group_4__0 )? ) ;
-    public final void rule__EndChecks__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14479:1: ( ( ( rule__EndChecks__Group_4__0 )? ) )
-            // InternalTestgeneratorDSL.g:14480:1: ( ( rule__EndChecks__Group_4__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:14480:1: ( ( rule__EndChecks__Group_4__0 )? )
-            // InternalTestgeneratorDSL.g:14481:2: ( rule__EndChecks__Group_4__0 )?
-            {
-             before(grammarAccess.getEndChecksAccess().getGroup_4()); 
-            // InternalTestgeneratorDSL.g:14482:2: ( rule__EndChecks__Group_4__0 )?
-            int alt105=2;
-            int LA105_0 = input.LA(1);
-
-            if ( (LA105_0==RULE_ID) ) {
-                alt105=1;
-            }
-            switch (alt105) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:14482:3: rule__EndChecks__Group_4__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__EndChecks__Group_4__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getEndChecksAccess().getGroup_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__4__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group__5"
-    // InternalTestgeneratorDSL.g:14490:1: rule__EndChecks__Group__5 : rule__EndChecks__Group__5__Impl ;
-    public final void rule__EndChecks__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14494:1: ( rule__EndChecks__Group__5__Impl )
-            // InternalTestgeneratorDSL.g:14495:2: rule__EndChecks__Group__5__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group__5__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__5"
-
-
-    // $ANTLR start "rule__EndChecks__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:14501:1: rule__EndChecks__Group__5__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__EndChecks__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14505:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:14506:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:14506:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:14507:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getLIST_CLOSEDTerminalRuleCall_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group__5__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4__0"
-    // InternalTestgeneratorDSL.g:14517:1: rule__EndChecks__Group_4__0 : rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1 ;
-    public final void rule__EndChecks__Group_4__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14521:1: ( rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1 )
-            // InternalTestgeneratorDSL.g:14522:2: rule__EndChecks__Group_4__0__Impl rule__EndChecks__Group_4__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__EndChecks__Group_4__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group_4__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4__0"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4__0__Impl"
-    // InternalTestgeneratorDSL.g:14529:1: rule__EndChecks__Group_4__0__Impl : ( ( rule__EndChecks__EndChecksAssignment_4_0 ) ) ;
-    public final void rule__EndChecks__Group_4__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14533:1: ( ( ( rule__EndChecks__EndChecksAssignment_4_0 ) ) )
-            // InternalTestgeneratorDSL.g:14534:1: ( ( rule__EndChecks__EndChecksAssignment_4_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14534:1: ( ( rule__EndChecks__EndChecksAssignment_4_0 ) )
-            // InternalTestgeneratorDSL.g:14535:2: ( rule__EndChecks__EndChecksAssignment_4_0 )
-            {
-             before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); 
-            // InternalTestgeneratorDSL.g:14536:2: ( rule__EndChecks__EndChecksAssignment_4_0 )
-            // InternalTestgeneratorDSL.g:14536:3: rule__EndChecks__EndChecksAssignment_4_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__EndChecksAssignment_4_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4__0__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4__1"
-    // InternalTestgeneratorDSL.g:14544:1: rule__EndChecks__Group_4__1 : rule__EndChecks__Group_4__1__Impl ;
-    public final void rule__EndChecks__Group_4__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14548:1: ( rule__EndChecks__Group_4__1__Impl )
-            // InternalTestgeneratorDSL.g:14549:2: rule__EndChecks__Group_4__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group_4__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4__1"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4__1__Impl"
-    // InternalTestgeneratorDSL.g:14555:1: rule__EndChecks__Group_4__1__Impl : ( ( rule__EndChecks__Group_4_1__0 )* ) ;
-    public final void rule__EndChecks__Group_4__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14559:1: ( ( ( rule__EndChecks__Group_4_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:14560:1: ( ( rule__EndChecks__Group_4_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:14560:1: ( ( rule__EndChecks__Group_4_1__0 )* )
-            // InternalTestgeneratorDSL.g:14561:2: ( rule__EndChecks__Group_4_1__0 )*
-            {
-             before(grammarAccess.getEndChecksAccess().getGroup_4_1()); 
-            // InternalTestgeneratorDSL.g:14562:2: ( rule__EndChecks__Group_4_1__0 )*
-            loop106:
-            do {
-                int alt106=2;
-                int LA106_0 = input.LA(1);
-
-                if ( (LA106_0==RULE_SEPARATOR) ) {
-                    alt106=1;
-                }
-
-
-                switch (alt106) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:14562:3: rule__EndChecks__Group_4_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__EndChecks__Group_4_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop106;
-                }
-            } while (true);
-
-             after(grammarAccess.getEndChecksAccess().getGroup_4_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4__1__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4_1__0"
-    // InternalTestgeneratorDSL.g:14571:1: rule__EndChecks__Group_4_1__0 : rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1 ;
-    public final void rule__EndChecks__Group_4_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14575:1: ( rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1 )
-            // InternalTestgeneratorDSL.g:14576:2: rule__EndChecks__Group_4_1__0__Impl rule__EndChecks__Group_4_1__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__EndChecks__Group_4_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group_4_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4_1__0"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4_1__0__Impl"
-    // InternalTestgeneratorDSL.g:14583:1: rule__EndChecks__Group_4_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__EndChecks__Group_4_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14587:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:14588:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:14588:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:14589:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4_1__0__Impl"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4_1__1"
-    // InternalTestgeneratorDSL.g:14598:1: rule__EndChecks__Group_4_1__1 : rule__EndChecks__Group_4_1__1__Impl ;
-    public final void rule__EndChecks__Group_4_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14602:1: ( rule__EndChecks__Group_4_1__1__Impl )
-            // InternalTestgeneratorDSL.g:14603:2: rule__EndChecks__Group_4_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__Group_4_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4_1__1"
-
-
-    // $ANTLR start "rule__EndChecks__Group_4_1__1__Impl"
-    // InternalTestgeneratorDSL.g:14609:1: rule__EndChecks__Group_4_1__1__Impl : ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) ) ;
-    public final void rule__EndChecks__Group_4_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14613:1: ( ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:14614:1: ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:14614:1: ( ( rule__EndChecks__EndChecksAssignment_4_1_1 ) )
-            // InternalTestgeneratorDSL.g:14615:2: ( rule__EndChecks__EndChecksAssignment_4_1_1 )
-            {
-             before(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); 
-            // InternalTestgeneratorDSL.g:14616:2: ( rule__EndChecks__EndChecksAssignment_4_1_1 )
-            // InternalTestgeneratorDSL.g:14616:3: rule__EndChecks__EndChecksAssignment_4_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__EndChecks__EndChecksAssignment_4_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getEndChecksAccess().getEndChecksAssignment_4_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__EndChecks__Group_4_1__1__Impl"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__0"
-    // InternalTestgeneratorDSL.g:14625:1: rule__StringVariableDeclaration__Group__0 : rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1 ;
-    public final void rule__StringVariableDeclaration__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14629:1: ( rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1 )
-            // InternalTestgeneratorDSL.g:14630:2: rule__StringVariableDeclaration__Group__0__Impl rule__StringVariableDeclaration__Group__1
-            {
-            pushFollow(FOLLOW_62);
-            rule__StringVariableDeclaration__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableDeclaration__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__0"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14637:1: rule__StringVariableDeclaration__Group__0__Impl : ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) ) ;
-    public final void rule__StringVariableDeclaration__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14641:1: ( ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:14642:1: ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14642:1: ( ( rule__StringVariableDeclaration__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:14643:2: ( rule__StringVariableDeclaration__KeyAssignment_0 )
-            {
-             before(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:14644:2: ( rule__StringVariableDeclaration__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:14644:3: rule__StringVariableDeclaration__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableDeclaration__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableDeclarationAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__0__Impl"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__1"
-    // InternalTestgeneratorDSL.g:14652:1: rule__StringVariableDeclaration__Group__1 : rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2 ;
-    public final void rule__StringVariableDeclaration__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14656:1: ( rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2 )
-            // InternalTestgeneratorDSL.g:14657:2: rule__StringVariableDeclaration__Group__1__Impl rule__StringVariableDeclaration__Group__2
-            {
-            pushFollow(FOLLOW_7);
-            rule__StringVariableDeclaration__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableDeclaration__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__1"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14664:1: rule__StringVariableDeclaration__Group__1__Impl : ( '=' ) ;
-    public final void rule__StringVariableDeclaration__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14668:1: ( ( '=' ) )
-            // InternalTestgeneratorDSL.g:14669:1: ( '=' )
-            {
-            // InternalTestgeneratorDSL.g:14669:1: ( '=' )
-            // InternalTestgeneratorDSL.g:14670:2: '='
-            {
-             before(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-            match(input,78,FOLLOW_2); 
-             after(grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__1__Impl"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__2"
-    // InternalTestgeneratorDSL.g:14679:1: rule__StringVariableDeclaration__Group__2 : rule__StringVariableDeclaration__Group__2__Impl ;
-    public final void rule__StringVariableDeclaration__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14683:1: ( rule__StringVariableDeclaration__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:14684:2: rule__StringVariableDeclaration__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableDeclaration__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__2"
-
-
-    // $ANTLR start "rule__StringVariableDeclaration__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14690:1: rule__StringVariableDeclaration__Group__2__Impl : ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) ) ;
-    public final void rule__StringVariableDeclaration__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14694:1: ( ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:14695:1: ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:14695:1: ( ( rule__StringVariableDeclaration__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:14696:2: ( rule__StringVariableDeclaration__ValueAssignment_2 )
-            {
-             before(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:14697:2: ( rule__StringVariableDeclaration__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:14697:3: rule__StringVariableDeclaration__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableDeclaration__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableDeclarationAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableDeclaration__Group__2__Impl"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__0"
-    // InternalTestgeneratorDSL.g:14706:1: rule__IntVariableDeclaration__Group__0 : rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1 ;
-    public final void rule__IntVariableDeclaration__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14710:1: ( rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1 )
-            // InternalTestgeneratorDSL.g:14711:2: rule__IntVariableDeclaration__Group__0__Impl rule__IntVariableDeclaration__Group__1
-            {
-            pushFollow(FOLLOW_62);
-            rule__IntVariableDeclaration__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableDeclaration__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__0"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14718:1: rule__IntVariableDeclaration__Group__0__Impl : ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) ) ;
-    public final void rule__IntVariableDeclaration__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14722:1: ( ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:14723:1: ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14723:1: ( ( rule__IntVariableDeclaration__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:14724:2: ( rule__IntVariableDeclaration__KeyAssignment_0 )
-            {
-             before(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:14725:2: ( rule__IntVariableDeclaration__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:14725:3: rule__IntVariableDeclaration__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableDeclaration__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableDeclarationAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__0__Impl"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__1"
-    // InternalTestgeneratorDSL.g:14733:1: rule__IntVariableDeclaration__Group__1 : rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2 ;
-    public final void rule__IntVariableDeclaration__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14737:1: ( rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2 )
-            // InternalTestgeneratorDSL.g:14738:2: rule__IntVariableDeclaration__Group__1__Impl rule__IntVariableDeclaration__Group__2
-            {
-            pushFollow(FOLLOW_43);
-            rule__IntVariableDeclaration__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableDeclaration__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__1"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14745:1: rule__IntVariableDeclaration__Group__1__Impl : ( '=' ) ;
-    public final void rule__IntVariableDeclaration__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14749:1: ( ( '=' ) )
-            // InternalTestgeneratorDSL.g:14750:1: ( '=' )
-            {
-            // InternalTestgeneratorDSL.g:14750:1: ( '=' )
-            // InternalTestgeneratorDSL.g:14751:2: '='
-            {
-             before(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-            match(input,78,FOLLOW_2); 
-             after(grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__1__Impl"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__2"
-    // InternalTestgeneratorDSL.g:14760:1: rule__IntVariableDeclaration__Group__2 : rule__IntVariableDeclaration__Group__2__Impl ;
-    public final void rule__IntVariableDeclaration__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14764:1: ( rule__IntVariableDeclaration__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:14765:2: rule__IntVariableDeclaration__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableDeclaration__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__2"
-
-
-    // $ANTLR start "rule__IntVariableDeclaration__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14771:1: rule__IntVariableDeclaration__Group__2__Impl : ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) ) ;
-    public final void rule__IntVariableDeclaration__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14775:1: ( ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:14776:1: ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:14776:1: ( ( rule__IntVariableDeclaration__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:14777:2: ( rule__IntVariableDeclaration__ValueAssignment_2 )
-            {
-             before(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:14778:2: ( rule__IntVariableDeclaration__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:14778:3: rule__IntVariableDeclaration__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableDeclaration__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableDeclarationAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableDeclaration__Group__2__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__0"
-    // InternalTestgeneratorDSL.g:14787:1: rule__BooleanVariableDeclaration__Group__0 : rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1 ;
-    public final void rule__BooleanVariableDeclaration__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14791:1: ( rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1 )
-            // InternalTestgeneratorDSL.g:14792:2: rule__BooleanVariableDeclaration__Group__0__Impl rule__BooleanVariableDeclaration__Group__1
-            {
-            pushFollow(FOLLOW_62);
-            rule__BooleanVariableDeclaration__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableDeclaration__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__0"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14799:1: rule__BooleanVariableDeclaration__Group__0__Impl : ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) ) ;
-    public final void rule__BooleanVariableDeclaration__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14803:1: ( ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:14804:1: ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14804:1: ( ( rule__BooleanVariableDeclaration__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:14805:2: ( rule__BooleanVariableDeclaration__KeyAssignment_0 )
-            {
-             before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:14806:2: ( rule__BooleanVariableDeclaration__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:14806:3: rule__BooleanVariableDeclaration__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableDeclaration__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableDeclarationAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__0__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__1"
-    // InternalTestgeneratorDSL.g:14814:1: rule__BooleanVariableDeclaration__Group__1 : rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2 ;
-    public final void rule__BooleanVariableDeclaration__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14818:1: ( rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2 )
-            // InternalTestgeneratorDSL.g:14819:2: rule__BooleanVariableDeclaration__Group__1__Impl rule__BooleanVariableDeclaration__Group__2
-            {
-            pushFollow(FOLLOW_45);
-            rule__BooleanVariableDeclaration__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableDeclaration__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__1"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14826:1: rule__BooleanVariableDeclaration__Group__1__Impl : ( '=' ) ;
-    public final void rule__BooleanVariableDeclaration__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14830:1: ( ( '=' ) )
-            // InternalTestgeneratorDSL.g:14831:1: ( '=' )
-            {
-            // InternalTestgeneratorDSL.g:14831:1: ( '=' )
-            // InternalTestgeneratorDSL.g:14832:2: '='
-            {
-             before(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-            match(input,78,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__1__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__2"
-    // InternalTestgeneratorDSL.g:14841:1: rule__BooleanVariableDeclaration__Group__2 : rule__BooleanVariableDeclaration__Group__2__Impl ;
-    public final void rule__BooleanVariableDeclaration__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14845:1: ( rule__BooleanVariableDeclaration__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:14846:2: rule__BooleanVariableDeclaration__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableDeclaration__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__2"
-
-
-    // $ANTLR start "rule__BooleanVariableDeclaration__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14852:1: rule__BooleanVariableDeclaration__Group__2__Impl : ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) ) ;
-    public final void rule__BooleanVariableDeclaration__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14856:1: ( ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:14857:1: ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:14857:1: ( ( rule__BooleanVariableDeclaration__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:14858:2: ( rule__BooleanVariableDeclaration__ValueAssignment_2 )
-            {
-             before(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:14859:2: ( rule__BooleanVariableDeclaration__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:14859:3: rule__BooleanVariableDeclaration__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableDeclaration__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableDeclarationAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableDeclaration__Group__2__Impl"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__0"
-    // InternalTestgeneratorDSL.g:14868:1: rule__StringVariableEquals__Group__0 : rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1 ;
-    public final void rule__StringVariableEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14872:1: ( rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:14873:2: rule__StringVariableEquals__Group__0__Impl rule__StringVariableEquals__Group__1
-            {
-            pushFollow(FOLLOW_63);
-            rule__StringVariableEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__0"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14880:1: rule__StringVariableEquals__Group__0__Impl : ( ( rule__StringVariableEquals__KeyAssignment_0 ) ) ;
-    public final void rule__StringVariableEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14884:1: ( ( ( rule__StringVariableEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:14885:1: ( ( rule__StringVariableEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14885:1: ( ( rule__StringVariableEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:14886:2: ( rule__StringVariableEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:14887:2: ( rule__StringVariableEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:14887:3: rule__StringVariableEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__1"
-    // InternalTestgeneratorDSL.g:14895:1: rule__StringVariableEquals__Group__1 : rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2 ;
-    public final void rule__StringVariableEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14899:1: ( rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:14900:2: rule__StringVariableEquals__Group__1__Impl rule__StringVariableEquals__Group__2
-            {
-            pushFollow(FOLLOW_7);
-            rule__StringVariableEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__1"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14907:1: rule__StringVariableEquals__Group__1__Impl : ( '==' ) ;
-    public final void rule__StringVariableEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14911:1: ( ( '==' ) )
-            // InternalTestgeneratorDSL.g:14912:1: ( '==' )
-            {
-            // InternalTestgeneratorDSL.g:14912:1: ( '==' )
-            // InternalTestgeneratorDSL.g:14913:2: '=='
-            {
-             before(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-            match(input,18,FOLLOW_2); 
-             after(grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__2"
-    // InternalTestgeneratorDSL.g:14922:1: rule__StringVariableEquals__Group__2 : rule__StringVariableEquals__Group__2__Impl ;
-    public final void rule__StringVariableEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14926:1: ( rule__StringVariableEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:14927:2: rule__StringVariableEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__2"
-
-
-    // $ANTLR start "rule__StringVariableEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:14933:1: rule__StringVariableEquals__Group__2__Impl : ( ( rule__StringVariableEquals__ValueAssignment_2 ) ) ;
-    public final void rule__StringVariableEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14937:1: ( ( ( rule__StringVariableEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:14938:1: ( ( rule__StringVariableEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:14938:1: ( ( rule__StringVariableEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:14939:2: ( rule__StringVariableEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:14940:2: ( rule__StringVariableEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:14940:3: rule__StringVariableEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__0"
-    // InternalTestgeneratorDSL.g:14949:1: rule__IntVariableEquals__Group__0 : rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1 ;
-    public final void rule__IntVariableEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14953:1: ( rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:14954:2: rule__IntVariableEquals__Group__0__Impl rule__IntVariableEquals__Group__1
-            {
-            pushFollow(FOLLOW_63);
-            rule__IntVariableEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__0"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:14961:1: rule__IntVariableEquals__Group__0__Impl : ( ( rule__IntVariableEquals__KeyAssignment_0 ) ) ;
-    public final void rule__IntVariableEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14965:1: ( ( ( rule__IntVariableEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:14966:1: ( ( rule__IntVariableEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:14966:1: ( ( rule__IntVariableEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:14967:2: ( rule__IntVariableEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:14968:2: ( rule__IntVariableEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:14968:3: rule__IntVariableEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__1"
-    // InternalTestgeneratorDSL.g:14976:1: rule__IntVariableEquals__Group__1 : rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2 ;
-    public final void rule__IntVariableEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14980:1: ( rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:14981:2: rule__IntVariableEquals__Group__1__Impl rule__IntVariableEquals__Group__2
-            {
-            pushFollow(FOLLOW_43);
-            rule__IntVariableEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__1"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:14988:1: rule__IntVariableEquals__Group__1__Impl : ( '==' ) ;
-    public final void rule__IntVariableEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:14992:1: ( ( '==' ) )
-            // InternalTestgeneratorDSL.g:14993:1: ( '==' )
-            {
-            // InternalTestgeneratorDSL.g:14993:1: ( '==' )
-            // InternalTestgeneratorDSL.g:14994:2: '=='
-            {
-             before(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-            match(input,18,FOLLOW_2); 
-             after(grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__2"
-    // InternalTestgeneratorDSL.g:15003:1: rule__IntVariableEquals__Group__2 : rule__IntVariableEquals__Group__2__Impl ;
-    public final void rule__IntVariableEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15007:1: ( rule__IntVariableEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:15008:2: rule__IntVariableEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__2"
-
-
-    // $ANTLR start "rule__IntVariableEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15014:1: rule__IntVariableEquals__Group__2__Impl : ( ( rule__IntVariableEquals__ValueAssignment_2 ) ) ;
-    public final void rule__IntVariableEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15018:1: ( ( ( rule__IntVariableEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:15019:1: ( ( rule__IntVariableEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:15019:1: ( ( rule__IntVariableEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:15020:2: ( rule__IntVariableEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:15021:2: ( rule__IntVariableEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:15021:3: rule__IntVariableEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__0"
-    // InternalTestgeneratorDSL.g:15030:1: rule__BooleanVariableEquals__Group__0 : rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1 ;
-    public final void rule__BooleanVariableEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15034:1: ( rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:15035:2: rule__BooleanVariableEquals__Group__0__Impl rule__BooleanVariableEquals__Group__1
-            {
-            pushFollow(FOLLOW_63);
-            rule__BooleanVariableEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__0"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15042:1: rule__BooleanVariableEquals__Group__0__Impl : ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) ) ;
-    public final void rule__BooleanVariableEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15046:1: ( ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:15047:1: ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15047:1: ( ( rule__BooleanVariableEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:15048:2: ( rule__BooleanVariableEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:15049:2: ( rule__BooleanVariableEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:15049:3: rule__BooleanVariableEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__1"
-    // InternalTestgeneratorDSL.g:15057:1: rule__BooleanVariableEquals__Group__1 : rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2 ;
-    public final void rule__BooleanVariableEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15061:1: ( rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:15062:2: rule__BooleanVariableEquals__Group__1__Impl rule__BooleanVariableEquals__Group__2
-            {
-            pushFollow(FOLLOW_45);
-            rule__BooleanVariableEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__1"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15069:1: rule__BooleanVariableEquals__Group__1__Impl : ( '==' ) ;
-    public final void rule__BooleanVariableEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15073:1: ( ( '==' ) )
-            // InternalTestgeneratorDSL.g:15074:1: ( '==' )
-            {
-            // InternalTestgeneratorDSL.g:15074:1: ( '==' )
-            // InternalTestgeneratorDSL.g:15075:2: '=='
-            {
-             before(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-            match(input,18,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__2"
-    // InternalTestgeneratorDSL.g:15084:1: rule__BooleanVariableEquals__Group__2 : rule__BooleanVariableEquals__Group__2__Impl ;
-    public final void rule__BooleanVariableEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15088:1: ( rule__BooleanVariableEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:15089:2: rule__BooleanVariableEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__2"
-
-
-    // $ANTLR start "rule__BooleanVariableEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15095:1: rule__BooleanVariableEquals__Group__2__Impl : ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) ) ;
-    public final void rule__BooleanVariableEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15099:1: ( ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:15100:1: ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:15100:1: ( ( rule__BooleanVariableEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:15101:2: ( rule__BooleanVariableEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:15102:2: ( rule__BooleanVariableEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:15102:3: rule__BooleanVariableEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__0"
-    // InternalTestgeneratorDSL.g:15111:1: rule__StringVariableNotEquals__Group__0 : rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1 ;
-    public final void rule__StringVariableNotEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15115:1: ( rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:15116:2: rule__StringVariableNotEquals__Group__0__Impl rule__StringVariableNotEquals__Group__1
-            {
-            pushFollow(FOLLOW_64);
-            rule__StringVariableNotEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableNotEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__0"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15123:1: rule__StringVariableNotEquals__Group__0__Impl : ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) ) ;
-    public final void rule__StringVariableNotEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15127:1: ( ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:15128:1: ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15128:1: ( ( rule__StringVariableNotEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:15129:2: ( rule__StringVariableNotEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:15130:2: ( rule__StringVariableNotEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:15130:3: rule__StringVariableNotEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableNotEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableNotEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__1"
-    // InternalTestgeneratorDSL.g:15138:1: rule__StringVariableNotEquals__Group__1 : rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2 ;
-    public final void rule__StringVariableNotEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15142:1: ( rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:15143:2: rule__StringVariableNotEquals__Group__1__Impl rule__StringVariableNotEquals__Group__2
-            {
-            pushFollow(FOLLOW_7);
-            rule__StringVariableNotEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__StringVariableNotEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__1"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15150:1: rule__StringVariableNotEquals__Group__1__Impl : ( '!=' ) ;
-    public final void rule__StringVariableNotEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15154:1: ( ( '!=' ) )
-            // InternalTestgeneratorDSL.g:15155:1: ( '!=' )
-            {
-            // InternalTestgeneratorDSL.g:15155:1: ( '!=' )
-            // InternalTestgeneratorDSL.g:15156:2: '!='
-            {
-             before(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-            match(input,19,FOLLOW_2); 
-             after(grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__2"
-    // InternalTestgeneratorDSL.g:15165:1: rule__StringVariableNotEquals__Group__2 : rule__StringVariableNotEquals__Group__2__Impl ;
-    public final void rule__StringVariableNotEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15169:1: ( rule__StringVariableNotEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:15170:2: rule__StringVariableNotEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableNotEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__2"
-
-
-    // $ANTLR start "rule__StringVariableNotEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15176:1: rule__StringVariableNotEquals__Group__2__Impl : ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) ) ;
-    public final void rule__StringVariableNotEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15180:1: ( ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:15181:1: ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:15181:1: ( ( rule__StringVariableNotEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:15182:2: ( rule__StringVariableNotEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:15183:2: ( rule__StringVariableNotEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:15183:3: rule__StringVariableNotEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringVariableNotEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringVariableNotEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__StringVariableNotEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__0"
-    // InternalTestgeneratorDSL.g:15192:1: rule__IntVariableNotEquals__Group__0 : rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1 ;
-    public final void rule__IntVariableNotEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15196:1: ( rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:15197:2: rule__IntVariableNotEquals__Group__0__Impl rule__IntVariableNotEquals__Group__1
-            {
-            pushFollow(FOLLOW_64);
-            rule__IntVariableNotEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableNotEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__0"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15204:1: rule__IntVariableNotEquals__Group__0__Impl : ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) ) ;
-    public final void rule__IntVariableNotEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15208:1: ( ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:15209:1: ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15209:1: ( ( rule__IntVariableNotEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:15210:2: ( rule__IntVariableNotEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:15211:2: ( rule__IntVariableNotEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:15211:3: rule__IntVariableNotEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableNotEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableNotEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__1"
-    // InternalTestgeneratorDSL.g:15219:1: rule__IntVariableNotEquals__Group__1 : rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2 ;
-    public final void rule__IntVariableNotEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15223:1: ( rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:15224:2: rule__IntVariableNotEquals__Group__1__Impl rule__IntVariableNotEquals__Group__2
-            {
-            pushFollow(FOLLOW_43);
-            rule__IntVariableNotEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__IntVariableNotEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__1"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15231:1: rule__IntVariableNotEquals__Group__1__Impl : ( '!=' ) ;
-    public final void rule__IntVariableNotEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15235:1: ( ( '!=' ) )
-            // InternalTestgeneratorDSL.g:15236:1: ( '!=' )
-            {
-            // InternalTestgeneratorDSL.g:15236:1: ( '!=' )
-            // InternalTestgeneratorDSL.g:15237:2: '!='
-            {
-             before(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-            match(input,19,FOLLOW_2); 
-             after(grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__2"
-    // InternalTestgeneratorDSL.g:15246:1: rule__IntVariableNotEquals__Group__2 : rule__IntVariableNotEquals__Group__2__Impl ;
-    public final void rule__IntVariableNotEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15250:1: ( rule__IntVariableNotEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:15251:2: rule__IntVariableNotEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableNotEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__2"
-
-
-    // $ANTLR start "rule__IntVariableNotEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15257:1: rule__IntVariableNotEquals__Group__2__Impl : ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) ) ;
-    public final void rule__IntVariableNotEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15261:1: ( ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:15262:1: ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:15262:1: ( ( rule__IntVariableNotEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:15263:2: ( rule__IntVariableNotEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:15264:2: ( rule__IntVariableNotEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:15264:3: rule__IntVariableNotEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntVariableNotEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntVariableNotEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__IntVariableNotEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__0"
-    // InternalTestgeneratorDSL.g:15273:1: rule__BooleanVariableNotEquals__Group__0 : rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1 ;
-    public final void rule__BooleanVariableNotEquals__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15277:1: ( rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1 )
-            // InternalTestgeneratorDSL.g:15278:2: rule__BooleanVariableNotEquals__Group__0__Impl rule__BooleanVariableNotEquals__Group__1
-            {
-            pushFollow(FOLLOW_64);
-            rule__BooleanVariableNotEquals__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableNotEquals__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__0"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15285:1: rule__BooleanVariableNotEquals__Group__0__Impl : ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) ) ;
-    public final void rule__BooleanVariableNotEquals__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15289:1: ( ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:15290:1: ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15290:1: ( ( rule__BooleanVariableNotEquals__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:15291:2: ( rule__BooleanVariableNotEquals__KeyAssignment_0 )
-            {
-             before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:15292:2: ( rule__BooleanVariableNotEquals__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:15292:3: rule__BooleanVariableNotEquals__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableNotEquals__KeyAssignment_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyAssignment_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__0__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__1"
-    // InternalTestgeneratorDSL.g:15300:1: rule__BooleanVariableNotEquals__Group__1 : rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2 ;
-    public final void rule__BooleanVariableNotEquals__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15304:1: ( rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2 )
-            // InternalTestgeneratorDSL.g:15305:2: rule__BooleanVariableNotEquals__Group__1__Impl rule__BooleanVariableNotEquals__Group__2
-            {
-            pushFollow(FOLLOW_45);
-            rule__BooleanVariableNotEquals__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableNotEquals__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__1"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15312:1: rule__BooleanVariableNotEquals__Group__1__Impl : ( '!=' ) ;
-    public final void rule__BooleanVariableNotEquals__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15316:1: ( ( '!=' ) )
-            // InternalTestgeneratorDSL.g:15317:1: ( '!=' )
-            {
-            // InternalTestgeneratorDSL.g:15317:1: ( '!=' )
-            // InternalTestgeneratorDSL.g:15318:2: '!='
-            {
-             before(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-            match(input,19,FOLLOW_2); 
-             after(grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__1__Impl"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__2"
-    // InternalTestgeneratorDSL.g:15327:1: rule__BooleanVariableNotEquals__Group__2 : rule__BooleanVariableNotEquals__Group__2__Impl ;
-    public final void rule__BooleanVariableNotEquals__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15331:1: ( rule__BooleanVariableNotEquals__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:15332:2: rule__BooleanVariableNotEquals__Group__2__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableNotEquals__Group__2__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__2"
-
-
-    // $ANTLR start "rule__BooleanVariableNotEquals__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15338:1: rule__BooleanVariableNotEquals__Group__2__Impl : ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) ) ;
-    public final void rule__BooleanVariableNotEquals__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15342:1: ( ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:15343:1: ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:15343:1: ( ( rule__BooleanVariableNotEquals__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:15344:2: ( rule__BooleanVariableNotEquals__ValueAssignment_2 )
-            {
-             before(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:15345:2: ( rule__BooleanVariableNotEquals__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:15345:3: rule__BooleanVariableNotEquals__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanVariableNotEquals__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanVariableNotEqualsAccess().getValueAssignment_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__BooleanVariableNotEquals__Group__2__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__0"
-    // InternalTestgeneratorDSL.g:15354:1: rule__ExternalServiceMock__Group__0 : rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1 ;
-    public final void rule__ExternalServiceMock__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15358:1: ( rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1 )
-            // InternalTestgeneratorDSL.g:15359:2: rule__ExternalServiceMock__Group__0__Impl rule__ExternalServiceMock__Group__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__ExternalServiceMock__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__0"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15366:1: rule__ExternalServiceMock__Group__0__Impl : ( 'ExternalServiceMock' ) ;
-    public final void rule__ExternalServiceMock__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15370:1: ( ( 'ExternalServiceMock' ) )
-            // InternalTestgeneratorDSL.g:15371:1: ( 'ExternalServiceMock' )
-            {
-            // InternalTestgeneratorDSL.g:15371:1: ( 'ExternalServiceMock' )
-            // InternalTestgeneratorDSL.g:15372:2: 'ExternalServiceMock'
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); 
-            match(input,79,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__0__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__1"
-    // InternalTestgeneratorDSL.g:15381:1: rule__ExternalServiceMock__Group__1 : rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2 ;
-    public final void rule__ExternalServiceMock__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15385:1: ( rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2 )
-            // InternalTestgeneratorDSL.g:15386:2: rule__ExternalServiceMock__Group__1__Impl rule__ExternalServiceMock__Group__2
-            {
-            pushFollow(FOLLOW_53);
-            rule__ExternalServiceMock__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__1"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15393:1: rule__ExternalServiceMock__Group__1__Impl : ( ( rule__ExternalServiceMock__NameAssignment_1 ) ) ;
-    public final void rule__ExternalServiceMock__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15397:1: ( ( ( rule__ExternalServiceMock__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:15398:1: ( ( rule__ExternalServiceMock__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:15398:1: ( ( rule__ExternalServiceMock__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:15399:2: ( rule__ExternalServiceMock__NameAssignment_1 )
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:15400:2: ( rule__ExternalServiceMock__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:15400:3: rule__ExternalServiceMock__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceMockAccess().getNameAssignment_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__1__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__2"
-    // InternalTestgeneratorDSL.g:15408:1: rule__ExternalServiceMock__Group__2 : rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3 ;
-    public final void rule__ExternalServiceMock__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15412:1: ( rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3 )
-            // InternalTestgeneratorDSL.g:15413:2: rule__ExternalServiceMock__Group__2__Impl rule__ExternalServiceMock__Group__3
-            {
-            pushFollow(FOLLOW_65);
-            rule__ExternalServiceMock__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__2"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15420:1: rule__ExternalServiceMock__Group__2__Impl : ( 'for' ) ;
-    public final void rule__ExternalServiceMock__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15424:1: ( ( 'for' ) )
-            // InternalTestgeneratorDSL.g:15425:1: ( 'for' )
-            {
-            // InternalTestgeneratorDSL.g:15425:1: ( 'for' )
-            // InternalTestgeneratorDSL.g:15426:2: 'for'
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); 
-            match(input,69,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceMockAccess().getForKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__2__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__3"
-    // InternalTestgeneratorDSL.g:15435:1: rule__ExternalServiceMock__Group__3 : rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4 ;
-    public final void rule__ExternalServiceMock__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15439:1: ( rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4 )
-            // InternalTestgeneratorDSL.g:15440:2: rule__ExternalServiceMock__Group__3__Impl rule__ExternalServiceMock__Group__4
-            {
-            pushFollow(FOLLOW_4);
-            rule__ExternalServiceMock__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__3"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:15447:1: rule__ExternalServiceMock__Group__3__Impl : ( 'topic' ) ;
-    public final void rule__ExternalServiceMock__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15451:1: ( ( 'topic' ) )
-            // InternalTestgeneratorDSL.g:15452:1: ( 'topic' )
-            {
-            // InternalTestgeneratorDSL.g:15452:1: ( 'topic' )
-            // InternalTestgeneratorDSL.g:15453:2: 'topic'
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); 
-            match(input,80,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__3__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__4"
-    // InternalTestgeneratorDSL.g:15462:1: rule__ExternalServiceMock__Group__4 : rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5 ;
-    public final void rule__ExternalServiceMock__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15466:1: ( rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5 )
-            // InternalTestgeneratorDSL.g:15467:2: rule__ExternalServiceMock__Group__4__Impl rule__ExternalServiceMock__Group__5
-            {
-            pushFollow(FOLLOW_10);
-            rule__ExternalServiceMock__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__4"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:15474:1: rule__ExternalServiceMock__Group__4__Impl : ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) ) ;
-    public final void rule__ExternalServiceMock__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15478:1: ( ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) ) )
-            // InternalTestgeneratorDSL.g:15479:1: ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) )
-            {
-            // InternalTestgeneratorDSL.g:15479:1: ( ( rule__ExternalServiceMock__ExternalTopicAssignment_4 ) )
-            // InternalTestgeneratorDSL.g:15480:2: ( rule__ExternalServiceMock__ExternalTopicAssignment_4 )
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); 
-            // InternalTestgeneratorDSL.g:15481:2: ( rule__ExternalServiceMock__ExternalTopicAssignment_4 )
-            // InternalTestgeneratorDSL.g:15481:3: rule__ExternalServiceMock__ExternalTopicAssignment_4
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__ExternalTopicAssignment_4();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceMockAccess().getExternalTopicAssignment_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__4__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__5"
-    // InternalTestgeneratorDSL.g:15489:1: rule__ExternalServiceMock__Group__5 : rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6 ;
-    public final void rule__ExternalServiceMock__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15493:1: ( rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6 )
-            // InternalTestgeneratorDSL.g:15494:2: rule__ExternalServiceMock__Group__5__Impl rule__ExternalServiceMock__Group__6
-            {
-            pushFollow(FOLLOW_10);
-            rule__ExternalServiceMock__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__5"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:15501:1: rule__ExternalServiceMock__Group__5__Impl : ( ( rule__ExternalServiceMock__Group_5__0 )? ) ;
-    public final void rule__ExternalServiceMock__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15505:1: ( ( ( rule__ExternalServiceMock__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:15506:1: ( ( rule__ExternalServiceMock__Group_5__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:15506:1: ( ( rule__ExternalServiceMock__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:15507:2: ( rule__ExternalServiceMock__Group_5__0 )?
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:15508:2: ( rule__ExternalServiceMock__Group_5__0 )?
-            int alt107=2;
-            int LA107_0 = input.LA(1);
-
-            if ( (LA107_0==28) ) {
-                alt107=1;
-            }
-            switch (alt107) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:15508:3: rule__ExternalServiceMock__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__ExternalServiceMock__Group_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getExternalServiceMockAccess().getGroup_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__5__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__6"
-    // InternalTestgeneratorDSL.g:15516:1: rule__ExternalServiceMock__Group__6 : rule__ExternalServiceMock__Group__6__Impl ;
-    public final void rule__ExternalServiceMock__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15520:1: ( rule__ExternalServiceMock__Group__6__Impl )
-            // InternalTestgeneratorDSL.g:15521:2: rule__ExternalServiceMock__Group__6__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group__6__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__6"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:15527:1: rule__ExternalServiceMock__Group__6__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__ExternalServiceMock__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15531:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:15532:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:15532:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:15533:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group__6__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5__0"
-    // InternalTestgeneratorDSL.g:15543:1: rule__ExternalServiceMock__Group_5__0 : rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1 ;
-    public final void rule__ExternalServiceMock__Group_5__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15547:1: ( rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1 )
-            // InternalTestgeneratorDSL.g:15548:2: rule__ExternalServiceMock__Group_5__0__Impl rule__ExternalServiceMock__Group_5__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__ExternalServiceMock__Group_5__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group_5__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5__0"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:15555:1: rule__ExternalServiceMock__Group_5__0__Impl : ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) ) ;
-    public final void rule__ExternalServiceMock__Group_5__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15559:1: ( ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:15560:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15560:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 ) )
-            // InternalTestgeneratorDSL.g:15561:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 )
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); 
-            // InternalTestgeneratorDSL.g:15562:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_0 )
-            // InternalTestgeneratorDSL.g:15562:3: rule__ExternalServiceMock__MockingRulesAssignment_5_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__MockingRulesAssignment_5_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5__0__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5__1"
-    // InternalTestgeneratorDSL.g:15570:1: rule__ExternalServiceMock__Group_5__1 : rule__ExternalServiceMock__Group_5__1__Impl ;
-    public final void rule__ExternalServiceMock__Group_5__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15574:1: ( rule__ExternalServiceMock__Group_5__1__Impl )
-            // InternalTestgeneratorDSL.g:15575:2: rule__ExternalServiceMock__Group_5__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group_5__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5__1"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:15581:1: rule__ExternalServiceMock__Group_5__1__Impl : ( ( rule__ExternalServiceMock__Group_5_1__0 )* ) ;
-    public final void rule__ExternalServiceMock__Group_5__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15585:1: ( ( ( rule__ExternalServiceMock__Group_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:15586:1: ( ( rule__ExternalServiceMock__Group_5_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:15586:1: ( ( rule__ExternalServiceMock__Group_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:15587:2: ( rule__ExternalServiceMock__Group_5_1__0 )*
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); 
-            // InternalTestgeneratorDSL.g:15588:2: ( rule__ExternalServiceMock__Group_5_1__0 )*
-            loop108:
-            do {
-                int alt108=2;
-                int LA108_0 = input.LA(1);
-
-                if ( (LA108_0==RULE_SEPARATOR) ) {
-                    alt108=1;
-                }
-
-
-                switch (alt108) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:15588:3: rule__ExternalServiceMock__Group_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__ExternalServiceMock__Group_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop108;
-                }
-            } while (true);
-
-             after(grammarAccess.getExternalServiceMockAccess().getGroup_5_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5__1__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__0"
-    // InternalTestgeneratorDSL.g:15597:1: rule__ExternalServiceMock__Group_5_1__0 : rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1 ;
-    public final void rule__ExternalServiceMock__Group_5_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15601:1: ( rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1 )
-            // InternalTestgeneratorDSL.g:15602:2: rule__ExternalServiceMock__Group_5_1__0__Impl rule__ExternalServiceMock__Group_5_1__1
-            {
-            pushFollow(FOLLOW_5);
-            rule__ExternalServiceMock__Group_5_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group_5_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__0"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:15609:1: rule__ExternalServiceMock__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__ExternalServiceMock__Group_5_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15613:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:15614:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:15614:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:15615:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__0__Impl"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__1"
-    // InternalTestgeneratorDSL.g:15624:1: rule__ExternalServiceMock__Group_5_1__1 : rule__ExternalServiceMock__Group_5_1__1__Impl ;
-    public final void rule__ExternalServiceMock__Group_5_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15628:1: ( rule__ExternalServiceMock__Group_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:15629:2: rule__ExternalServiceMock__Group_5_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__Group_5_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__1"
-
-
-    // $ANTLR start "rule__ExternalServiceMock__Group_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:15635:1: rule__ExternalServiceMock__Group_5_1__1__Impl : ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) ) ;
-    public final void rule__ExternalServiceMock__Group_5_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15639:1: ( ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:15640:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:15640:1: ( ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:15641:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 )
-            {
-             before(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); 
-            // InternalTestgeneratorDSL.g:15642:2: ( rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 )
-            // InternalTestgeneratorDSL.g:15642:3: rule__ExternalServiceMock__MockingRulesAssignment_5_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__ExternalServiceMock__MockingRulesAssignment_5_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getExternalServiceMockAccess().getMockingRulesAssignment_5_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ExternalServiceMock__Group_5_1__1__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__0"
-    // InternalTestgeneratorDSL.g:15651:1: rule__DelegateMock__Group__0 : rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1 ;
-    public final void rule__DelegateMock__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15655:1: ( rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1 )
-            // InternalTestgeneratorDSL.g:15656:2: rule__DelegateMock__Group__0__Impl rule__DelegateMock__Group__1
-            {
-            pushFollow(FOLLOW_4);
-            rule__DelegateMock__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__0"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:15663:1: rule__DelegateMock__Group__0__Impl : ( 'DelegateMock' ) ;
-    public final void rule__DelegateMock__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15667:1: ( ( 'DelegateMock' ) )
-            // InternalTestgeneratorDSL.g:15668:1: ( 'DelegateMock' )
-            {
-            // InternalTestgeneratorDSL.g:15668:1: ( 'DelegateMock' )
-            // InternalTestgeneratorDSL.g:15669:2: 'DelegateMock'
-            {
-             before(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); 
-            match(input,81,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__0__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__1"
-    // InternalTestgeneratorDSL.g:15678:1: rule__DelegateMock__Group__1 : rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2 ;
-    public final void rule__DelegateMock__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15682:1: ( rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2 )
-            // InternalTestgeneratorDSL.g:15683:2: rule__DelegateMock__Group__1__Impl rule__DelegateMock__Group__2
-            {
-            pushFollow(FOLLOW_53);
-            rule__DelegateMock__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__1"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:15690:1: rule__DelegateMock__Group__1__Impl : ( ( rule__DelegateMock__NameAssignment_1 ) ) ;
-    public final void rule__DelegateMock__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15694:1: ( ( ( rule__DelegateMock__NameAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:15695:1: ( ( rule__DelegateMock__NameAssignment_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:15695:1: ( ( rule__DelegateMock__NameAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:15696:2: ( rule__DelegateMock__NameAssignment_1 )
-            {
-             before(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); 
-            // InternalTestgeneratorDSL.g:15697:2: ( rule__DelegateMock__NameAssignment_1 )
-            // InternalTestgeneratorDSL.g:15697:3: rule__DelegateMock__NameAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__NameAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getNameAssignment_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__1__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__2"
-    // InternalTestgeneratorDSL.g:15705:1: rule__DelegateMock__Group__2 : rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3 ;
-    public final void rule__DelegateMock__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15709:1: ( rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3 )
-            // InternalTestgeneratorDSL.g:15710:2: rule__DelegateMock__Group__2__Impl rule__DelegateMock__Group__3
-            {
-            pushFollow(FOLLOW_4);
-            rule__DelegateMock__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__2"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:15717:1: rule__DelegateMock__Group__2__Impl : ( 'for' ) ;
-    public final void rule__DelegateMock__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15721:1: ( ( 'for' ) )
-            // InternalTestgeneratorDSL.g:15722:1: ( 'for' )
-            {
-            // InternalTestgeneratorDSL.g:15722:1: ( 'for' )
-            // InternalTestgeneratorDSL.g:15723:2: 'for'
-            {
-             before(grammarAccess.getDelegateMockAccess().getForKeyword_2()); 
-            match(input,69,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getForKeyword_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__2__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__3"
-    // InternalTestgeneratorDSL.g:15732:1: rule__DelegateMock__Group__3 : rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4 ;
-    public final void rule__DelegateMock__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15736:1: ( rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4 )
-            // InternalTestgeneratorDSL.g:15737:2: rule__DelegateMock__Group__3__Impl rule__DelegateMock__Group__4
-            {
-            pushFollow(FOLLOW_5);
-            rule__DelegateMock__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__3"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:15744:1: rule__DelegateMock__Group__3__Impl : ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) ) ;
-    public final void rule__DelegateMock__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15748:1: ( ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) ) )
-            // InternalTestgeneratorDSL.g:15749:1: ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) )
-            {
-            // InternalTestgeneratorDSL.g:15749:1: ( ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 ) )
-            // InternalTestgeneratorDSL.g:15750:2: ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 )
-            {
-             before(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); 
-            // InternalTestgeneratorDSL.g:15751:2: ( rule__DelegateMock__ServiceTaskReferenceAssignment_3 )
-            // InternalTestgeneratorDSL.g:15751:3: rule__DelegateMock__ServiceTaskReferenceAssignment_3
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__ServiceTaskReferenceAssignment_3();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceAssignment_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__3__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__4"
-    // InternalTestgeneratorDSL.g:15759:1: rule__DelegateMock__Group__4 : rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5 ;
-    public final void rule__DelegateMock__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15763:1: ( rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5 )
-            // InternalTestgeneratorDSL.g:15764:2: rule__DelegateMock__Group__4__Impl rule__DelegateMock__Group__5
-            {
-            pushFollow(FOLLOW_33);
-            rule__DelegateMock__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__4"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:15771:1: rule__DelegateMock__Group__4__Impl : ( 'with' ) ;
-    public final void rule__DelegateMock__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15775:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:15776:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:15776:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:15777:2: 'with'
-            {
-             before(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getWithKeyword_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__4__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__5"
-    // InternalTestgeneratorDSL.g:15786:1: rule__DelegateMock__Group__5 : rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6 ;
-    public final void rule__DelegateMock__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15790:1: ( rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6 )
-            // InternalTestgeneratorDSL.g:15791:2: rule__DelegateMock__Group__5__Impl rule__DelegateMock__Group__6
-            {
-            pushFollow(FOLLOW_7);
-            rule__DelegateMock__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__5"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:15798:1: rule__DelegateMock__Group__5__Impl : ( 'delegate' ) ;
-    public final void rule__DelegateMock__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15802:1: ( ( 'delegate' ) )
-            // InternalTestgeneratorDSL.g:15803:1: ( 'delegate' )
-            {
-            // InternalTestgeneratorDSL.g:15803:1: ( 'delegate' )
-            // InternalTestgeneratorDSL.g:15804:2: 'delegate'
-            {
-             before(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); 
-            match(input,48,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getDelegateKeyword_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__5__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__6"
-    // InternalTestgeneratorDSL.g:15813:1: rule__DelegateMock__Group__6 : rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7 ;
-    public final void rule__DelegateMock__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15817:1: ( rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7 )
-            // InternalTestgeneratorDSL.g:15818:2: rule__DelegateMock__Group__6__Impl rule__DelegateMock__Group__7
-            {
-            pushFollow(FOLLOW_10);
-            rule__DelegateMock__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__6"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:15825:1: rule__DelegateMock__Group__6__Impl : ( ( rule__DelegateMock__DelegateClassAssignment_6 ) ) ;
-    public final void rule__DelegateMock__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15829:1: ( ( ( rule__DelegateMock__DelegateClassAssignment_6 ) ) )
-            // InternalTestgeneratorDSL.g:15830:1: ( ( rule__DelegateMock__DelegateClassAssignment_6 ) )
-            {
-            // InternalTestgeneratorDSL.g:15830:1: ( ( rule__DelegateMock__DelegateClassAssignment_6 ) )
-            // InternalTestgeneratorDSL.g:15831:2: ( rule__DelegateMock__DelegateClassAssignment_6 )
-            {
-             before(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); 
-            // InternalTestgeneratorDSL.g:15832:2: ( rule__DelegateMock__DelegateClassAssignment_6 )
-            // InternalTestgeneratorDSL.g:15832:3: rule__DelegateMock__DelegateClassAssignment_6
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__DelegateClassAssignment_6();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getDelegateClassAssignment_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__6__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__7"
-    // InternalTestgeneratorDSL.g:15840:1: rule__DelegateMock__Group__7 : rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8 ;
-    public final void rule__DelegateMock__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15844:1: ( rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8 )
-            // InternalTestgeneratorDSL.g:15845:2: rule__DelegateMock__Group__7__Impl rule__DelegateMock__Group__8
-            {
-            pushFollow(FOLLOW_10);
-            rule__DelegateMock__Group__7__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__8();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__7"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:15852:1: rule__DelegateMock__Group__7__Impl : ( ( rule__DelegateMock__Group_7__0 )? ) ;
-    public final void rule__DelegateMock__Group__7__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15856:1: ( ( ( rule__DelegateMock__Group_7__0 )? ) )
-            // InternalTestgeneratorDSL.g:15857:1: ( ( rule__DelegateMock__Group_7__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:15857:1: ( ( rule__DelegateMock__Group_7__0 )? )
-            // InternalTestgeneratorDSL.g:15858:2: ( rule__DelegateMock__Group_7__0 )?
-            {
-             before(grammarAccess.getDelegateMockAccess().getGroup_7()); 
-            // InternalTestgeneratorDSL.g:15859:2: ( rule__DelegateMock__Group_7__0 )?
-            int alt109=2;
-            int LA109_0 = input.LA(1);
-
-            if ( (LA109_0==28) ) {
-                alt109=1;
-            }
-            switch (alt109) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:15859:3: rule__DelegateMock__Group_7__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__DelegateMock__Group_7__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getGroup_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__7__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__8"
-    // InternalTestgeneratorDSL.g:15867:1: rule__DelegateMock__Group__8 : rule__DelegateMock__Group__8__Impl ;
-    public final void rule__DelegateMock__Group__8() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15871:1: ( rule__DelegateMock__Group__8__Impl )
-            // InternalTestgeneratorDSL.g:15872:2: rule__DelegateMock__Group__8__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group__8__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__8"
-
-
-    // $ANTLR start "rule__DelegateMock__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:15878:1: rule__DelegateMock__Group__8__Impl : ( RULE_DECLARATION_FINISHED ) ;
-    public final void rule__DelegateMock__Group__8__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15882:1: ( ( RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:15883:1: ( RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:15883:1: ( RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:15884:2: RULE_DECLARATION_FINISHED
-            {
-             before(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-            match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getDECLARATION_FINISHEDTerminalRuleCall_8()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group__8__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7__0"
-    // InternalTestgeneratorDSL.g:15894:1: rule__DelegateMock__Group_7__0 : rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1 ;
-    public final void rule__DelegateMock__Group_7__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15898:1: ( rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1 )
-            // InternalTestgeneratorDSL.g:15899:2: rule__DelegateMock__Group_7__0__Impl rule__DelegateMock__Group_7__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__DelegateMock__Group_7__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group_7__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7__0"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7__0__Impl"
-    // InternalTestgeneratorDSL.g:15906:1: rule__DelegateMock__Group_7__0__Impl : ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) ) ;
-    public final void rule__DelegateMock__Group_7__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15910:1: ( ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) ) )
-            // InternalTestgeneratorDSL.g:15911:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:15911:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_0 ) )
-            // InternalTestgeneratorDSL.g:15912:2: ( rule__DelegateMock__ManualMocksAssignment_7_0 )
-            {
-             before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); 
-            // InternalTestgeneratorDSL.g:15913:2: ( rule__DelegateMock__ManualMocksAssignment_7_0 )
-            // InternalTestgeneratorDSL.g:15913:3: rule__DelegateMock__ManualMocksAssignment_7_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__ManualMocksAssignment_7_0();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7__0__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7__1"
-    // InternalTestgeneratorDSL.g:15921:1: rule__DelegateMock__Group_7__1 : rule__DelegateMock__Group_7__1__Impl ;
-    public final void rule__DelegateMock__Group_7__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15925:1: ( rule__DelegateMock__Group_7__1__Impl )
-            // InternalTestgeneratorDSL.g:15926:2: rule__DelegateMock__Group_7__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group_7__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7__1"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7__1__Impl"
-    // InternalTestgeneratorDSL.g:15932:1: rule__DelegateMock__Group_7__1__Impl : ( ( rule__DelegateMock__Group_7_1__0 )* ) ;
-    public final void rule__DelegateMock__Group_7__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15936:1: ( ( ( rule__DelegateMock__Group_7_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:15937:1: ( ( rule__DelegateMock__Group_7_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:15937:1: ( ( rule__DelegateMock__Group_7_1__0 )* )
-            // InternalTestgeneratorDSL.g:15938:2: ( rule__DelegateMock__Group_7_1__0 )*
-            {
-             before(grammarAccess.getDelegateMockAccess().getGroup_7_1()); 
-            // InternalTestgeneratorDSL.g:15939:2: ( rule__DelegateMock__Group_7_1__0 )*
-            loop110:
-            do {
-                int alt110=2;
-                int LA110_0 = input.LA(1);
-
-                if ( (LA110_0==RULE_SEPARATOR) ) {
-                    alt110=1;
-                }
-
-
-                switch (alt110) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:15939:3: rule__DelegateMock__Group_7_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__DelegateMock__Group_7_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop110;
-                }
-            } while (true);
-
-             after(grammarAccess.getDelegateMockAccess().getGroup_7_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7__1__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7_1__0"
-    // InternalTestgeneratorDSL.g:15948:1: rule__DelegateMock__Group_7_1__0 : rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1 ;
-    public final void rule__DelegateMock__Group_7_1__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15952:1: ( rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1 )
-            // InternalTestgeneratorDSL.g:15953:2: rule__DelegateMock__Group_7_1__0__Impl rule__DelegateMock__Group_7_1__1
-            {
-            pushFollow(FOLLOW_5);
-            rule__DelegateMock__Group_7_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group_7_1__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7_1__0"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7_1__0__Impl"
-    // InternalTestgeneratorDSL.g:15960:1: rule__DelegateMock__Group_7_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__DelegateMock__Group_7_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15964:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:15965:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:15965:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:15966:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7_1__0__Impl"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7_1__1"
-    // InternalTestgeneratorDSL.g:15975:1: rule__DelegateMock__Group_7_1__1 : rule__DelegateMock__Group_7_1__1__Impl ;
-    public final void rule__DelegateMock__Group_7_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15979:1: ( rule__DelegateMock__Group_7_1__1__Impl )
-            // InternalTestgeneratorDSL.g:15980:2: rule__DelegateMock__Group_7_1__1__Impl
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__Group_7_1__1__Impl();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7_1__1"
-
-
-    // $ANTLR start "rule__DelegateMock__Group_7_1__1__Impl"
-    // InternalTestgeneratorDSL.g:15986:1: rule__DelegateMock__Group_7_1__1__Impl : ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) ) ;
-    public final void rule__DelegateMock__Group_7_1__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:15990:1: ( ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:15991:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:15991:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) )
-            // InternalTestgeneratorDSL.g:15992:2: ( rule__DelegateMock__ManualMocksAssignment_7_1_1 )
-            {
-             before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); 
-            // InternalTestgeneratorDSL.g:15993:2: ( rule__DelegateMock__ManualMocksAssignment_7_1_1 )
-            // InternalTestgeneratorDSL.g:15993:3: rule__DelegateMock__ManualMocksAssignment_7_1_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__DelegateMock__ManualMocksAssignment_7_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateMock__Group_7_1__1__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__0"
-    // InternalTestgeneratorDSL.g:16002:1: rule__MockingRule__Group__0 : rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1 ;
-    public final void rule__MockingRule__Group__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16006:1: ( rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1 )
-            // InternalTestgeneratorDSL.g:16007:2: rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1
-            {
-            pushFollow(FOLLOW_66);
-            rule__MockingRule__Group__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__1();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__0"
-
-
-    // $ANTLR start "rule__MockingRule__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:16014:1: rule__MockingRule__Group__0__Impl : ( 'with' ) ;
-    public final void rule__MockingRule__Group__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16018:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:16019:1: ( 'with' )
-            {
-            // InternalTestgeneratorDSL.g:16019:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:16020:2: 'with'
-            {
-             before(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__0__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__1"
-    // InternalTestgeneratorDSL.g:16029:1: rule__MockingRule__Group__1 : rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2 ;
-    public final void rule__MockingRule__Group__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16033:1: ( rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2 )
-            // InternalTestgeneratorDSL.g:16034:2: rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2
-            {
-            pushFollow(FOLLOW_12);
-            rule__MockingRule__Group__1__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__2();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__1"
-
-
-    // $ANTLR start "rule__MockingRule__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:16041:1: rule__MockingRule__Group__1__Impl : ( 'rule' ) ;
-    public final void rule__MockingRule__Group__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16045:1: ( ( 'rule' ) )
-            // InternalTestgeneratorDSL.g:16046:1: ( 'rule' )
-            {
-            // InternalTestgeneratorDSL.g:16046:1: ( 'rule' )
-            // InternalTestgeneratorDSL.g:16047:2: 'rule'
-            {
-             before(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); 
-            match(input,82,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__1__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__2"
-    // InternalTestgeneratorDSL.g:16056:1: rule__MockingRule__Group__2 : rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3 ;
-    public final void rule__MockingRule__Group__2() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16060:1: ( rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3 )
-            // InternalTestgeneratorDSL.g:16061:2: rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3
-            {
-            pushFollow(FOLLOW_67);
-            rule__MockingRule__Group__2__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__3();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__2"
-
-
-    // $ANTLR start "rule__MockingRule__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:16068:1: rule__MockingRule__Group__2__Impl : ( RULE_ASSOCIATION ) ;
-    public final void rule__MockingRule__Group__2__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16072:1: ( ( RULE_ASSOCIATION ) )
-            // InternalTestgeneratorDSL.g:16073:1: ( RULE_ASSOCIATION )
-            {
-            // InternalTestgeneratorDSL.g:16073:1: ( RULE_ASSOCIATION )
-            // InternalTestgeneratorDSL.g:16074:2: RULE_ASSOCIATION
-            {
-             before(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); 
-            match(input,RULE_ASSOCIATION,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__2__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__3"
-    // InternalTestgeneratorDSL.g:16083:1: rule__MockingRule__Group__3 : rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4 ;
-    public final void rule__MockingRule__Group__3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16087:1: ( rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4 )
-            // InternalTestgeneratorDSL.g:16088:2: rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4
-            {
-            pushFollow(FOLLOW_13);
-            rule__MockingRule__Group__3__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__4();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__3"
-
-
-    // $ANTLR start "rule__MockingRule__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:16095:1: rule__MockingRule__Group__3__Impl : ( 'if' ) ;
-    public final void rule__MockingRule__Group__3__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16099:1: ( ( 'if' ) )
-            // InternalTestgeneratorDSL.g:16100:1: ( 'if' )
-            {
-            // InternalTestgeneratorDSL.g:16100:1: ( 'if' )
-            // InternalTestgeneratorDSL.g:16101:2: 'if'
-            {
-             before(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); 
-            match(input,83,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__3__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__4"
-    // InternalTestgeneratorDSL.g:16110:1: rule__MockingRule__Group__4 : rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5 ;
-    public final void rule__MockingRule__Group__4() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16114:1: ( rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5 )
-            // InternalTestgeneratorDSL.g:16115:2: rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5
-            {
-            pushFollow(FOLLOW_21);
-            rule__MockingRule__Group__4__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__5();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__4"
-
-
-    // $ANTLR start "rule__MockingRule__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:16122:1: rule__MockingRule__Group__4__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__MockingRule__Group__4__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16126:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:16127:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:16127:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:16128:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__4__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__5"
-    // InternalTestgeneratorDSL.g:16137:1: rule__MockingRule__Group__5 : rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6 ;
-    public final void rule__MockingRule__Group__5() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16141:1: ( rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6 )
-            // InternalTestgeneratorDSL.g:16142:2: rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6
-            {
-            pushFollow(FOLLOW_21);
-            rule__MockingRule__Group__5__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__6();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__5"
-
-
-    // $ANTLR start "rule__MockingRule__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:16149:1: rule__MockingRule__Group__5__Impl : ( ( rule__MockingRule__Group_5__0 )? ) ;
-    public final void rule__MockingRule__Group__5__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16153:1: ( ( ( rule__MockingRule__Group_5__0 )? ) )
-            // InternalTestgeneratorDSL.g:16154:1: ( ( rule__MockingRule__Group_5__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:16154:1: ( ( rule__MockingRule__Group_5__0 )? )
-            // InternalTestgeneratorDSL.g:16155:2: ( rule__MockingRule__Group_5__0 )?
-            {
-             before(grammarAccess.getMockingRuleAccess().getGroup_5()); 
-            // InternalTestgeneratorDSL.g:16156:2: ( rule__MockingRule__Group_5__0 )?
-            int alt111=2;
-            int LA111_0 = input.LA(1);
-
-            if ( (LA111_0==RULE_ID) ) {
-                alt111=1;
-            }
-            switch (alt111) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:16156:3: rule__MockingRule__Group_5__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__MockingRule__Group_5__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getMockingRuleAccess().getGroup_5()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__5__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__6"
-    // InternalTestgeneratorDSL.g:16164:1: rule__MockingRule__Group__6 : rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7 ;
-    public final void rule__MockingRule__Group__6() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16168:1: ( rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7 )
-            // InternalTestgeneratorDSL.g:16169:2: rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7
-            {
-            pushFollow(FOLLOW_68);
-            rule__MockingRule__Group__6__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__7();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__6"
-
-
-    // $ANTLR start "rule__MockingRule__Group__6__Impl"
-    // InternalTestgeneratorDSL.g:16176:1: rule__MockingRule__Group__6__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__MockingRule__Group__6__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16180:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:16181:1: ( RULE_LIST_CLOSED )
-            {
-            // InternalTestgeneratorDSL.g:16181:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:16182:2: RULE_LIST_CLOSED
-            {
-             before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__6__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__7"
-    // InternalTestgeneratorDSL.g:16191:1: rule__MockingRule__Group__7 : rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8 ;
-    public final void rule__MockingRule__Group__7() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16195:1: ( rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8 )
-            // InternalTestgeneratorDSL.g:16196:2: rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8
-            {
-            pushFollow(FOLLOW_13);
-            rule__MockingRule__Group__7__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__8();
-
-            state._fsp--;
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__7"
-
-
-    // $ANTLR start "rule__MockingRule__Group__7__Impl"
-    // InternalTestgeneratorDSL.g:16203:1: rule__MockingRule__Group__7__Impl : ( 'set' ) ;
-    public final void rule__MockingRule__Group__7__Impl() throws RecognitionException {
+    // $ANTLR start "rule__DelegateMock__Group_7_1__1__Impl"
+    // InternalTestgeneratorDSL.g:11807:1: rule__DelegateMock__Group_7_1__1__Impl : ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) ) ;
+    public final void rule__DelegateMock__Group_7_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16207:1: ( ( 'set' ) )
-            // InternalTestgeneratorDSL.g:16208:1: ( 'set' )
+            // InternalTestgeneratorDSL.g:11811:1: ( ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:11812:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:16208:1: ( 'set' )
-            // InternalTestgeneratorDSL.g:16209:2: 'set'
+            // InternalTestgeneratorDSL.g:11812:1: ( ( rule__DelegateMock__ManualMocksAssignment_7_1_1 ) )
+            // InternalTestgeneratorDSL.g:11813:2: ( rule__DelegateMock__ManualMocksAssignment_7_1_1 )
             {
-             before(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); 
-            match(input,84,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__7__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__8"
-    // InternalTestgeneratorDSL.g:16218:1: rule__MockingRule__Group__8 : rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9 ;
-    public final void rule__MockingRule__Group__8() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16222:1: ( rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9 )
-            // InternalTestgeneratorDSL.g:16223:2: rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9
+             before(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); 
+            // InternalTestgeneratorDSL.g:11814:2: ( rule__DelegateMock__ManualMocksAssignment_7_1_1 )
+            // InternalTestgeneratorDSL.g:11814:3: rule__DelegateMock__ManualMocksAssignment_7_1_1
             {
-            pushFollow(FOLLOW_21);
-            rule__MockingRule__Group__8__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__9();
+            rule__DelegateMock__ManualMocksAssignment_7_1_1();
 
             state._fsp--;
 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__8"
-
-
-    // $ANTLR start "rule__MockingRule__Group__8__Impl"
-    // InternalTestgeneratorDSL.g:16230:1: rule__MockingRule__Group__8__Impl : ( RULE_LIST_OPEN ) ;
-    public final void rule__MockingRule__Group__8__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16234:1: ( ( RULE_LIST_OPEN ) )
-            // InternalTestgeneratorDSL.g:16235:1: ( RULE_LIST_OPEN )
-            {
-            // InternalTestgeneratorDSL.g:16235:1: ( RULE_LIST_OPEN )
-            // InternalTestgeneratorDSL.g:16236:2: RULE_LIST_OPEN
-            {
-             before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); 
-            match(input,RULE_LIST_OPEN,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); 
+             after(grammarAccess.getDelegateMockAccess().getManualMocksAssignment_7_1_1()); 
 
             }
 
@@ -49148,117 +35789,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group__8__Impl"
+    // $ANTLR end "rule__DelegateMock__Group_7_1__1__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group__9"
-    // InternalTestgeneratorDSL.g:16245:1: rule__MockingRule__Group__9 : rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10 ;
-    public final void rule__MockingRule__Group__9() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__0"
+    // InternalTestgeneratorDSL.g:11823:1: rule__MockingRule__Group__0 : rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1 ;
+    public final void rule__MockingRule__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16249:1: ( rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10 )
-            // InternalTestgeneratorDSL.g:16250:2: rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10
+            // InternalTestgeneratorDSL.g:11827:1: ( rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1 )
+            // InternalTestgeneratorDSL.g:11828:2: rule__MockingRule__Group__0__Impl rule__MockingRule__Group__1
             {
-            pushFollow(FOLLOW_21);
-            rule__MockingRule__Group__9__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__10();
+            pushFollow(FOLLOW_64);
+            rule__MockingRule__Group__0__Impl();
 
             state._fsp--;
 
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__9"
-
-
-    // $ANTLR start "rule__MockingRule__Group__9__Impl"
-    // InternalTestgeneratorDSL.g:16257:1: rule__MockingRule__Group__9__Impl : ( ( rule__MockingRule__Group_9__0 )? ) ;
-    public final void rule__MockingRule__Group__9__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16261:1: ( ( ( rule__MockingRule__Group_9__0 )? ) )
-            // InternalTestgeneratorDSL.g:16262:1: ( ( rule__MockingRule__Group_9__0 )? )
-            {
-            // InternalTestgeneratorDSL.g:16262:1: ( ( rule__MockingRule__Group_9__0 )? )
-            // InternalTestgeneratorDSL.g:16263:2: ( rule__MockingRule__Group_9__0 )?
-            {
-             before(grammarAccess.getMockingRuleAccess().getGroup_9()); 
-            // InternalTestgeneratorDSL.g:16264:2: ( rule__MockingRule__Group_9__0 )?
-            int alt112=2;
-            int LA112_0 = input.LA(1);
-
-            if ( (LA112_0==RULE_ID) ) {
-                alt112=1;
-            }
-            switch (alt112) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:16264:3: rule__MockingRule__Group_9__0
-                    {
-                    pushFollow(FOLLOW_2);
-                    rule__MockingRule__Group_9__0();
-
-                    state._fsp--;
-
-
-                    }
-                    break;
-
-            }
-
-             after(grammarAccess.getMockingRuleAccess().getGroup_9()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__9__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group__10"
-    // InternalTestgeneratorDSL.g:16272:1: rule__MockingRule__Group__10 : rule__MockingRule__Group__10__Impl ;
-    public final void rule__MockingRule__Group__10() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16276:1: ( rule__MockingRule__Group__10__Impl )
-            // InternalTestgeneratorDSL.g:16277:2: rule__MockingRule__Group__10__Impl
-            {
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group__10__Impl();
+            rule__MockingRule__Group__1();
 
             state._fsp--;
 
@@ -49277,66 +35827,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group__10"
+    // $ANTLR end "rule__MockingRule__Group__0"
 
 
-    // $ANTLR start "rule__MockingRule__Group__10__Impl"
-    // InternalTestgeneratorDSL.g:16283:1: rule__MockingRule__Group__10__Impl : ( RULE_LIST_CLOSED ) ;
-    public final void rule__MockingRule__Group__10__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:11835:1: rule__MockingRule__Group__0__Impl : ( 'with' ) ;
+    public final void rule__MockingRule__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16287:1: ( ( RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:16288:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:11839:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:11840:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:16288:1: ( RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:16289:2: RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:11840:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:11841:2: 'with'
             {
-             before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
-            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
-
-            }
-
+             before(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getWithKeyword_0()); 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group__10__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group_5__0"
-    // InternalTestgeneratorDSL.g:16299:1: rule__MockingRule__Group_5__0 : rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1 ;
-    public final void rule__MockingRule__Group_5__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16303:1: ( rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1 )
-            // InternalTestgeneratorDSL.g:16304:2: rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__MockingRule__Group_5__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_5__1();
-
-            state._fsp--;
-
 
             }
 
@@ -49352,68 +35864,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_5__0"
+    // $ANTLR end "rule__MockingRule__Group__0__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group_5__0__Impl"
-    // InternalTestgeneratorDSL.g:16311:1: rule__MockingRule__Group_5__0__Impl : ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) ) ;
-    public final void rule__MockingRule__Group_5__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__1"
+    // InternalTestgeneratorDSL.g:11850:1: rule__MockingRule__Group__1 : rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2 ;
+    public final void rule__MockingRule__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16315:1: ( ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) ) )
-            // InternalTestgeneratorDSL.g:16316:1: ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) )
-            {
-            // InternalTestgeneratorDSL.g:16316:1: ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) )
-            // InternalTestgeneratorDSL.g:16317:2: ( rule__MockingRule__ComparisonsAssignment_5_0 )
-            {
-             before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); 
-            // InternalTestgeneratorDSL.g:16318:2: ( rule__MockingRule__ComparisonsAssignment_5_0 )
-            // InternalTestgeneratorDSL.g:16318:3: rule__MockingRule__ComparisonsAssignment_5_0
+            // InternalTestgeneratorDSL.g:11854:1: ( rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2 )
+            // InternalTestgeneratorDSL.g:11855:2: rule__MockingRule__Group__1__Impl rule__MockingRule__Group__2
             {
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__ComparisonsAssignment_5_0();
+            pushFollow(FOLLOW_12);
+            rule__MockingRule__Group__1__Impl();
 
             state._fsp--;
 
-
-            }
-
-             after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group_5__0__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group_5__1"
-    // InternalTestgeneratorDSL.g:16326:1: rule__MockingRule__Group_5__1 : rule__MockingRule__Group_5__1__Impl ;
-    public final void rule__MockingRule__Group_5__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16330:1: ( rule__MockingRule__Group_5__1__Impl )
-            // InternalTestgeneratorDSL.g:16331:2: rule__MockingRule__Group_5__1__Impl
-            {
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_5__1__Impl();
+            rule__MockingRule__Group__2();
 
             state._fsp--;
 
@@ -49432,53 +35902,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_5__1"
+    // $ANTLR end "rule__MockingRule__Group__1"
 
 
-    // $ANTLR start "rule__MockingRule__Group_5__1__Impl"
-    // InternalTestgeneratorDSL.g:16337:1: rule__MockingRule__Group_5__1__Impl : ( ( rule__MockingRule__Group_5_1__0 )* ) ;
-    public final void rule__MockingRule__Group_5__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:11862:1: rule__MockingRule__Group__1__Impl : ( 'rule' ) ;
+    public final void rule__MockingRule__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16341:1: ( ( ( rule__MockingRule__Group_5_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:16342:1: ( ( rule__MockingRule__Group_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:11866:1: ( ( 'rule' ) )
+            // InternalTestgeneratorDSL.g:11867:1: ( 'rule' )
             {
-            // InternalTestgeneratorDSL.g:16342:1: ( ( rule__MockingRule__Group_5_1__0 )* )
-            // InternalTestgeneratorDSL.g:16343:2: ( rule__MockingRule__Group_5_1__0 )*
+            // InternalTestgeneratorDSL.g:11867:1: ( 'rule' )
+            // InternalTestgeneratorDSL.g:11868:2: 'rule'
             {
-             before(grammarAccess.getMockingRuleAccess().getGroup_5_1()); 
-            // InternalTestgeneratorDSL.g:16344:2: ( rule__MockingRule__Group_5_1__0 )*
-            loop113:
-            do {
-                int alt113=2;
-                int LA113_0 = input.LA(1);
-
-                if ( (LA113_0==RULE_SEPARATOR) ) {
-                    alt113=1;
-                }
-
-
-                switch (alt113) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:16344:3: rule__MockingRule__Group_5_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__MockingRule__Group_5_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
-
-            	default :
-            	    break loop113;
-                }
-            } while (true);
-
-             after(grammarAccess.getMockingRuleAccess().getGroup_5_1()); 
+             before(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); 
+            match(input,81,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getRuleKeyword_1()); 
 
             }
 
@@ -49497,96 +35939,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_5__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group__1__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group_5_1__0"
-    // InternalTestgeneratorDSL.g:16353:1: rule__MockingRule__Group_5_1__0 : rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1 ;
-    public final void rule__MockingRule__Group_5_1__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__2"
+    // InternalTestgeneratorDSL.g:11877:1: rule__MockingRule__Group__2 : rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3 ;
+    public final void rule__MockingRule__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16357:1: ( rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1 )
-            // InternalTestgeneratorDSL.g:16358:2: rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1
+            // InternalTestgeneratorDSL.g:11881:1: ( rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3 )
+            // InternalTestgeneratorDSL.g:11882:2: rule__MockingRule__Group__2__Impl rule__MockingRule__Group__3
             {
-            pushFollow(FOLLOW_4);
-            rule__MockingRule__Group_5_1__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_5_1__1();
+            pushFollow(FOLLOW_65);
+            rule__MockingRule__Group__2__Impl();
 
             state._fsp--;
 
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group_5_1__0"
-
-
-    // $ANTLR start "rule__MockingRule__Group_5_1__0__Impl"
-    // InternalTestgeneratorDSL.g:16365:1: rule__MockingRule__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__MockingRule__Group_5_1__0__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16369:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:16370:1: ( RULE_SEPARATOR )
-            {
-            // InternalTestgeneratorDSL.g:16370:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:16371:2: RULE_SEPARATOR
-            {
-             before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group_5_1__0__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group_5_1__1"
-    // InternalTestgeneratorDSL.g:16380:1: rule__MockingRule__Group_5_1__1 : rule__MockingRule__Group_5_1__1__Impl ;
-    public final void rule__MockingRule__Group_5_1__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16384:1: ( rule__MockingRule__Group_5_1__1__Impl )
-            // InternalTestgeneratorDSL.g:16385:2: rule__MockingRule__Group_5_1__1__Impl
-            {
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_5_1__1__Impl();
+            rule__MockingRule__Group__3();
 
             state._fsp--;
 
@@ -49605,76 +35977,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_5_1__1"
+    // $ANTLR end "rule__MockingRule__Group__2"
 
 
-    // $ANTLR start "rule__MockingRule__Group_5_1__1__Impl"
-    // InternalTestgeneratorDSL.g:16391:1: rule__MockingRule__Group_5_1__1__Impl : ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) ) ;
-    public final void rule__MockingRule__Group_5_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:11889:1: rule__MockingRule__Group__2__Impl : ( RULE_ASSOCIATION ) ;
+    public final void rule__MockingRule__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16395:1: ( ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:16396:1: ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:16396:1: ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) )
-            // InternalTestgeneratorDSL.g:16397:2: ( rule__MockingRule__ComparisonsAssignment_5_1_1 )
+            // InternalTestgeneratorDSL.g:11893:1: ( ( RULE_ASSOCIATION ) )
+            // InternalTestgeneratorDSL.g:11894:1: ( RULE_ASSOCIATION )
             {
-             before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); 
-            // InternalTestgeneratorDSL.g:16398:2: ( rule__MockingRule__ComparisonsAssignment_5_1_1 )
-            // InternalTestgeneratorDSL.g:16398:3: rule__MockingRule__ComparisonsAssignment_5_1_1
+            // InternalTestgeneratorDSL.g:11894:1: ( RULE_ASSOCIATION )
+            // InternalTestgeneratorDSL.g:11895:2: RULE_ASSOCIATION
             {
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__ComparisonsAssignment_5_1_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); 
-
-            }
-
+             before(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); 
+            match(input,RULE_ASSOCIATION,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2()); 
 
             }
 
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group_5_1__1__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group_9__0"
-    // InternalTestgeneratorDSL.g:16407:1: rule__MockingRule__Group_9__0 : rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1 ;
-    public final void rule__MockingRule__Group_9__0() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16411:1: ( rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1 )
-            // InternalTestgeneratorDSL.g:16412:2: rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1
-            {
-            pushFollow(FOLLOW_15);
-            rule__MockingRule__Group_9__0__Impl();
-
-            state._fsp--;
-
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_9__1();
-
-            state._fsp--;
-
 
             }
 
@@ -49690,68 +36014,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9__0"
+    // $ANTLR end "rule__MockingRule__Group__2__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group_9__0__Impl"
-    // InternalTestgeneratorDSL.g:16419:1: rule__MockingRule__Group_9__0__Impl : ( ( rule__MockingRule__VariablesAssignment_9_0 ) ) ;
-    public final void rule__MockingRule__Group_9__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__3"
+    // InternalTestgeneratorDSL.g:11904:1: rule__MockingRule__Group__3 : rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4 ;
+    public final void rule__MockingRule__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16423:1: ( ( ( rule__MockingRule__VariablesAssignment_9_0 ) ) )
-            // InternalTestgeneratorDSL.g:16424:1: ( ( rule__MockingRule__VariablesAssignment_9_0 ) )
+            // InternalTestgeneratorDSL.g:11908:1: ( rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4 )
+            // InternalTestgeneratorDSL.g:11909:2: rule__MockingRule__Group__3__Impl rule__MockingRule__Group__4
             {
-            // InternalTestgeneratorDSL.g:16424:1: ( ( rule__MockingRule__VariablesAssignment_9_0 ) )
-            // InternalTestgeneratorDSL.g:16425:2: ( rule__MockingRule__VariablesAssignment_9_0 )
-            {
-             before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); 
-            // InternalTestgeneratorDSL.g:16426:2: ( rule__MockingRule__VariablesAssignment_9_0 )
-            // InternalTestgeneratorDSL.g:16426:3: rule__MockingRule__VariablesAssignment_9_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__VariablesAssignment_9_0();
+            pushFollow(FOLLOW_13);
+            rule__MockingRule__Group__3__Impl();
 
             state._fsp--;
 
-
-            }
-
-             after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__MockingRule__Group_9__0__Impl"
-
-
-    // $ANTLR start "rule__MockingRule__Group_9__1"
-    // InternalTestgeneratorDSL.g:16434:1: rule__MockingRule__Group_9__1 : rule__MockingRule__Group_9__1__Impl ;
-    public final void rule__MockingRule__Group_9__1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16438:1: ( rule__MockingRule__Group_9__1__Impl )
-            // InternalTestgeneratorDSL.g:16439:2: rule__MockingRule__Group_9__1__Impl
-            {
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_9__1__Impl();
+            rule__MockingRule__Group__4();
 
             state._fsp--;
 
@@ -49770,53 +36052,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9__1"
-
-
-    // $ANTLR start "rule__MockingRule__Group_9__1__Impl"
-    // InternalTestgeneratorDSL.g:16445:1: rule__MockingRule__Group_9__1__Impl : ( ( rule__MockingRule__Group_9_1__0 )* ) ;
-    public final void rule__MockingRule__Group_9__1__Impl() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:16449:1: ( ( ( rule__MockingRule__Group_9_1__0 )* ) )
-            // InternalTestgeneratorDSL.g:16450:1: ( ( rule__MockingRule__Group_9_1__0 )* )
-            {
-            // InternalTestgeneratorDSL.g:16450:1: ( ( rule__MockingRule__Group_9_1__0 )* )
-            // InternalTestgeneratorDSL.g:16451:2: ( rule__MockingRule__Group_9_1__0 )*
-            {
-             before(grammarAccess.getMockingRuleAccess().getGroup_9_1()); 
-            // InternalTestgeneratorDSL.g:16452:2: ( rule__MockingRule__Group_9_1__0 )*
-            loop114:
-            do {
-                int alt114=2;
-                int LA114_0 = input.LA(1);
-
-                if ( (LA114_0==RULE_SEPARATOR) ) {
-                    alt114=1;
-                }
-
-
-                switch (alt114) {
-            	case 1 :
-            	    // InternalTestgeneratorDSL.g:16452:3: rule__MockingRule__Group_9_1__0
-            	    {
-            	    pushFollow(FOLLOW_16);
-            	    rule__MockingRule__Group_9_1__0();
-
-            	    state._fsp--;
-
-
-            	    }
-            	    break;
+    // $ANTLR end "rule__MockingRule__Group__3"
 
-            	default :
-            	    break loop114;
-                }
-            } while (true);
 
-             after(grammarAccess.getMockingRuleAccess().getGroup_9_1()); 
+    // $ANTLR start "rule__MockingRule__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:11916:1: rule__MockingRule__Group__3__Impl : ( 'if' ) ;
+    public final void rule__MockingRule__Group__3__Impl() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:11920:1: ( ( 'if' ) )
+            // InternalTestgeneratorDSL.g:11921:1: ( 'if' )
+            {
+            // InternalTestgeneratorDSL.g:11921:1: ( 'if' )
+            // InternalTestgeneratorDSL.g:11922:2: 'if'
+            {
+             before(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); 
+            match(input,82,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getIfKeyword_3()); 
 
             }
 
@@ -49835,26 +36089,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group__3__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group_9_1__0"
-    // InternalTestgeneratorDSL.g:16461:1: rule__MockingRule__Group_9_1__0 : rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1 ;
-    public final void rule__MockingRule__Group_9_1__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__4"
+    // InternalTestgeneratorDSL.g:11931:1: rule__MockingRule__Group__4 : rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5 ;
+    public final void rule__MockingRule__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16465:1: ( rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1 )
-            // InternalTestgeneratorDSL.g:16466:2: rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1
+            // InternalTestgeneratorDSL.g:11935:1: ( rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5 )
+            // InternalTestgeneratorDSL.g:11936:2: rule__MockingRule__Group__4__Impl rule__MockingRule__Group__5
             {
-            pushFollow(FOLLOW_4);
-            rule__MockingRule__Group_9_1__0__Impl();
+            pushFollow(FOLLOW_20);
+            rule__MockingRule__Group__4__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_9_1__1();
+            rule__MockingRule__Group__5();
 
             state._fsp--;
 
@@ -49873,25 +36127,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9_1__0"
+    // $ANTLR end "rule__MockingRule__Group__4"
 
 
-    // $ANTLR start "rule__MockingRule__Group_9_1__0__Impl"
-    // InternalTestgeneratorDSL.g:16473:1: rule__MockingRule__Group_9_1__0__Impl : ( RULE_SEPARATOR ) ;
-    public final void rule__MockingRule__Group_9_1__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:11943:1: rule__MockingRule__Group__4__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__MockingRule__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16477:1: ( ( RULE_SEPARATOR ) )
-            // InternalTestgeneratorDSL.g:16478:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:11947:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:11948:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:16478:1: ( RULE_SEPARATOR )
-            // InternalTestgeneratorDSL.g:16479:2: RULE_SEPARATOR
+            // InternalTestgeneratorDSL.g:11948:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:11949:2: RULE_LIST_OPEN
             {
-             before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
-            match(input,RULE_SEPARATOR,FOLLOW_2); 
-             after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
+             before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4()); 
 
             }
 
@@ -49910,21 +36164,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9_1__0__Impl"
+    // $ANTLR end "rule__MockingRule__Group__4__Impl"
 
 
-    // $ANTLR start "rule__MockingRule__Group_9_1__1"
-    // InternalTestgeneratorDSL.g:16488:1: rule__MockingRule__Group_9_1__1 : rule__MockingRule__Group_9_1__1__Impl ;
-    public final void rule__MockingRule__Group_9_1__1() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__5"
+    // InternalTestgeneratorDSL.g:11958:1: rule__MockingRule__Group__5 : rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6 ;
+    public final void rule__MockingRule__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16492:1: ( rule__MockingRule__Group_9_1__1__Impl )
-            // InternalTestgeneratorDSL.g:16493:2: rule__MockingRule__Group_9_1__1__Impl
+            // InternalTestgeneratorDSL.g:11962:1: ( rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6 )
+            // InternalTestgeneratorDSL.g:11963:2: rule__MockingRule__Group__5__Impl rule__MockingRule__Group__6
             {
+            pushFollow(FOLLOW_20);
+            rule__MockingRule__Group__5__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__MockingRule__Group_9_1__1__Impl();
+            rule__MockingRule__Group__6();
 
             state._fsp--;
 
@@ -49943,35 +36202,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9_1__1"
+    // $ANTLR end "rule__MockingRule__Group__5"
 
 
-    // $ANTLR start "rule__MockingRule__Group_9_1__1__Impl"
-    // InternalTestgeneratorDSL.g:16499:1: rule__MockingRule__Group_9_1__1__Impl : ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) ) ;
-    public final void rule__MockingRule__Group_9_1__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:11970:1: rule__MockingRule__Group__5__Impl : ( ( rule__MockingRule__Group_5__0 )? ) ;
+    public final void rule__MockingRule__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16503:1: ( ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) ) )
-            // InternalTestgeneratorDSL.g:16504:1: ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) )
-            {
-            // InternalTestgeneratorDSL.g:16504:1: ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) )
-            // InternalTestgeneratorDSL.g:16505:2: ( rule__MockingRule__VariablesAssignment_9_1_1 )
+            // InternalTestgeneratorDSL.g:11974:1: ( ( ( rule__MockingRule__Group_5__0 )? ) )
+            // InternalTestgeneratorDSL.g:11975:1: ( ( rule__MockingRule__Group_5__0 )? )
             {
-             before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); 
-            // InternalTestgeneratorDSL.g:16506:2: ( rule__MockingRule__VariablesAssignment_9_1_1 )
-            // InternalTestgeneratorDSL.g:16506:3: rule__MockingRule__VariablesAssignment_9_1_1
+            // InternalTestgeneratorDSL.g:11975:1: ( ( rule__MockingRule__Group_5__0 )? )
+            // InternalTestgeneratorDSL.g:11976:2: ( rule__MockingRule__Group_5__0 )?
             {
-            pushFollow(FOLLOW_2);
-            rule__MockingRule__VariablesAssignment_9_1_1();
+             before(grammarAccess.getMockingRuleAccess().getGroup_5()); 
+            // InternalTestgeneratorDSL.g:11977:2: ( rule__MockingRule__Group_5__0 )?
+            int alt70=2;
+            int LA70_0 = input.LA(1);
+
+            if ( (LA70_0==RULE_ID) ) {
+                alt70=1;
+            }
+            switch (alt70) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:11977:3: rule__MockingRule__Group_5__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__MockingRule__Group_5__0();
+
+                    state._fsp--;
 
-            state._fsp--;
 
+                    }
+                    break;
 
             }
 
-             after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); 
+             after(grammarAccess.getMockingRuleAccess().getGroup_5()); 
 
             }
 
@@ -49990,26 +36260,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__MockingRule__Group_9_1__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group__5__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__0"
-    // InternalTestgeneratorDSL.g:16515:1: rule__ManualMock__Group__0 : rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1 ;
-    public final void rule__ManualMock__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__6"
+    // InternalTestgeneratorDSL.g:11985:1: rule__MockingRule__Group__6 : rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7 ;
+    public final void rule__MockingRule__Group__6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16519:1: ( rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1 )
-            // InternalTestgeneratorDSL.g:16520:2: rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1
+            // InternalTestgeneratorDSL.g:11989:1: ( rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7 )
+            // InternalTestgeneratorDSL.g:11990:2: rule__MockingRule__Group__6__Impl rule__MockingRule__Group__7
             {
-            pushFollow(FOLLOW_69);
-            rule__ManualMock__Group__0__Impl();
+            pushFollow(FOLLOW_66);
+            rule__MockingRule__Group__6__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__1();
+            rule__MockingRule__Group__7();
 
             state._fsp--;
 
@@ -50028,25 +36298,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__0"
+    // $ANTLR end "rule__MockingRule__Group__6"
 
 
-    // $ANTLR start "rule__ManualMock__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:16527:1: rule__ManualMock__Group__0__Impl : ( 'with' ) ;
-    public final void rule__ManualMock__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__6__Impl"
+    // InternalTestgeneratorDSL.g:11997:1: rule__MockingRule__Group__6__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__MockingRule__Group__6__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16531:1: ( ( 'with' ) )
-            // InternalTestgeneratorDSL.g:16532:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:12001:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:12002:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:16532:1: ( 'with' )
-            // InternalTestgeneratorDSL.g:16533:2: 'with'
+            // InternalTestgeneratorDSL.g:12002:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:12003:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getManualMockAccess().getWithKeyword_0()); 
-            match(input,28,FOLLOW_2); 
-             after(grammarAccess.getManualMockAccess().getWithKeyword_0()); 
+             before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6()); 
 
             }
 
@@ -50065,26 +36335,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__0__Impl"
+    // $ANTLR end "rule__MockingRule__Group__6__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__1"
-    // InternalTestgeneratorDSL.g:16542:1: rule__ManualMock__Group__1 : rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2 ;
-    public final void rule__ManualMock__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__7"
+    // InternalTestgeneratorDSL.g:12012:1: rule__MockingRule__Group__7 : rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8 ;
+    public final void rule__MockingRule__Group__7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16546:1: ( rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2 )
-            // InternalTestgeneratorDSL.g:16547:2: rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2
+            // InternalTestgeneratorDSL.g:12016:1: ( rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8 )
+            // InternalTestgeneratorDSL.g:12017:2: rule__MockingRule__Group__7__Impl rule__MockingRule__Group__8
             {
-            pushFollow(FOLLOW_7);
-            rule__ManualMock__Group__1__Impl();
+            pushFollow(FOLLOW_13);
+            rule__MockingRule__Group__7__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__2();
+            rule__MockingRule__Group__8();
 
             state._fsp--;
 
@@ -50103,25 +36373,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__1"
+    // $ANTLR end "rule__MockingRule__Group__7"
 
 
-    // $ANTLR start "rule__ManualMock__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:16554:1: rule__ManualMock__Group__1__Impl : ( 'manual' ) ;
-    public final void rule__ManualMock__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__7__Impl"
+    // InternalTestgeneratorDSL.g:12024:1: rule__MockingRule__Group__7__Impl : ( 'set' ) ;
+    public final void rule__MockingRule__Group__7__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16558:1: ( ( 'manual' ) )
-            // InternalTestgeneratorDSL.g:16559:1: ( 'manual' )
+            // InternalTestgeneratorDSL.g:12028:1: ( ( 'set' ) )
+            // InternalTestgeneratorDSL.g:12029:1: ( 'set' )
             {
-            // InternalTestgeneratorDSL.g:16559:1: ( 'manual' )
-            // InternalTestgeneratorDSL.g:16560:2: 'manual'
+            // InternalTestgeneratorDSL.g:12029:1: ( 'set' )
+            // InternalTestgeneratorDSL.g:12030:2: 'set'
             {
-             before(grammarAccess.getManualMockAccess().getManualKeyword_1()); 
-            match(input,85,FOLLOW_2); 
-             after(grammarAccess.getManualMockAccess().getManualKeyword_1()); 
+             before(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); 
+            match(input,83,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getSetKeyword_7()); 
 
             }
 
@@ -50140,26 +36410,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group__7__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__2"
-    // InternalTestgeneratorDSL.g:16569:1: rule__ManualMock__Group__2 : rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3 ;
-    public final void rule__ManualMock__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__8"
+    // InternalTestgeneratorDSL.g:12039:1: rule__MockingRule__Group__8 : rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9 ;
+    public final void rule__MockingRule__Group__8() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16573:1: ( rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3 )
-            // InternalTestgeneratorDSL.g:16574:2: rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3
+            // InternalTestgeneratorDSL.g:12043:1: ( rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9 )
+            // InternalTestgeneratorDSL.g:12044:2: rule__MockingRule__Group__8__Impl rule__MockingRule__Group__9
             {
-            pushFollow(FOLLOW_48);
-            rule__ManualMock__Group__2__Impl();
+            pushFollow(FOLLOW_20);
+            rule__MockingRule__Group__8__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__3();
+            rule__MockingRule__Group__9();
 
             state._fsp--;
 
@@ -50178,35 +36448,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__2"
+    // $ANTLR end "rule__MockingRule__Group__8"
 
 
-    // $ANTLR start "rule__ManualMock__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:16581:1: rule__ManualMock__Group__2__Impl : ( ( rule__ManualMock__ServiceNameAssignment_2 ) ) ;
-    public final void rule__ManualMock__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__8__Impl"
+    // InternalTestgeneratorDSL.g:12051:1: rule__MockingRule__Group__8__Impl : ( RULE_LIST_OPEN ) ;
+    public final void rule__MockingRule__Group__8__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16585:1: ( ( ( rule__ManualMock__ServiceNameAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:16586:1: ( ( rule__ManualMock__ServiceNameAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12055:1: ( ( RULE_LIST_OPEN ) )
+            // InternalTestgeneratorDSL.g:12056:1: ( RULE_LIST_OPEN )
             {
-            // InternalTestgeneratorDSL.g:16586:1: ( ( rule__ManualMock__ServiceNameAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:16587:2: ( rule__ManualMock__ServiceNameAssignment_2 )
-            {
-             before(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); 
-            // InternalTestgeneratorDSL.g:16588:2: ( rule__ManualMock__ServiceNameAssignment_2 )
-            // InternalTestgeneratorDSL.g:16588:3: rule__ManualMock__ServiceNameAssignment_2
+            // InternalTestgeneratorDSL.g:12056:1: ( RULE_LIST_OPEN )
+            // InternalTestgeneratorDSL.g:12057:2: RULE_LIST_OPEN
             {
-            pushFollow(FOLLOW_2);
-            rule__ManualMock__ServiceNameAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); 
+             before(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); 
+            match(input,RULE_LIST_OPEN,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8()); 
 
             }
 
@@ -50225,26 +36485,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__2__Impl"
+    // $ANTLR end "rule__MockingRule__Group__8__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__3"
-    // InternalTestgeneratorDSL.g:16596:1: rule__ManualMock__Group__3 : rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4 ;
-    public final void rule__ManualMock__Group__3() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__9"
+    // InternalTestgeneratorDSL.g:12066:1: rule__MockingRule__Group__9 : rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10 ;
+    public final void rule__MockingRule__Group__9() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16600:1: ( rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4 )
-            // InternalTestgeneratorDSL.g:16601:2: rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4
+            // InternalTestgeneratorDSL.g:12070:1: ( rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10 )
+            // InternalTestgeneratorDSL.g:12071:2: rule__MockingRule__Group__9__Impl rule__MockingRule__Group__10
             {
-            pushFollow(FOLLOW_70);
-            rule__ManualMock__Group__3__Impl();
+            pushFollow(FOLLOW_20);
+            rule__MockingRule__Group__9__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__4();
+            rule__MockingRule__Group__10();
 
             state._fsp--;
 
@@ -50263,25 +36523,46 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__3"
+    // $ANTLR end "rule__MockingRule__Group__9"
 
 
-    // $ANTLR start "rule__ManualMock__Group__3__Impl"
-    // InternalTestgeneratorDSL.g:16608:1: rule__ManualMock__Group__3__Impl : ( 'by' ) ;
-    public final void rule__ManualMock__Group__3__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__9__Impl"
+    // InternalTestgeneratorDSL.g:12078:1: rule__MockingRule__Group__9__Impl : ( ( rule__MockingRule__Group_9__0 )? ) ;
+    public final void rule__MockingRule__Group__9__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16612:1: ( ( 'by' ) )
-            // InternalTestgeneratorDSL.g:16613:1: ( 'by' )
+            // InternalTestgeneratorDSL.g:12082:1: ( ( ( rule__MockingRule__Group_9__0 )? ) )
+            // InternalTestgeneratorDSL.g:12083:1: ( ( rule__MockingRule__Group_9__0 )? )
             {
-            // InternalTestgeneratorDSL.g:16613:1: ( 'by' )
-            // InternalTestgeneratorDSL.g:16614:2: 'by'
+            // InternalTestgeneratorDSL.g:12083:1: ( ( rule__MockingRule__Group_9__0 )? )
+            // InternalTestgeneratorDSL.g:12084:2: ( rule__MockingRule__Group_9__0 )?
             {
-             before(grammarAccess.getManualMockAccess().getByKeyword_3()); 
-            match(input,63,FOLLOW_2); 
-             after(grammarAccess.getManualMockAccess().getByKeyword_3()); 
+             before(grammarAccess.getMockingRuleAccess().getGroup_9()); 
+            // InternalTestgeneratorDSL.g:12085:2: ( rule__MockingRule__Group_9__0 )?
+            int alt71=2;
+            int LA71_0 = input.LA(1);
+
+            if ( (LA71_0==RULE_ID) ) {
+                alt71=1;
+            }
+            switch (alt71) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:12085:3: rule__MockingRule__Group_9__0
+                    {
+                    pushFollow(FOLLOW_2);
+                    rule__MockingRule__Group_9__0();
+
+                    state._fsp--;
+
+
+                    }
+                    break;
+
+            }
+
+             after(grammarAccess.getMockingRuleAccess().getGroup_9()); 
 
             }
 
@@ -50300,26 +36581,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__3__Impl"
+    // $ANTLR end "rule__MockingRule__Group__9__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__4"
-    // InternalTestgeneratorDSL.g:16623:1: rule__ManualMock__Group__4 : rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5 ;
-    public final void rule__ManualMock__Group__4() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__10"
+    // InternalTestgeneratorDSL.g:12093:1: rule__MockingRule__Group__10 : rule__MockingRule__Group__10__Impl ;
+    public final void rule__MockingRule__Group__10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16627:1: ( rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5 )
-            // InternalTestgeneratorDSL.g:16628:2: rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5
+            // InternalTestgeneratorDSL.g:12097:1: ( rule__MockingRule__Group__10__Impl )
+            // InternalTestgeneratorDSL.g:12098:2: rule__MockingRule__Group__10__Impl
             {
-            pushFollow(FOLLOW_7);
-            rule__ManualMock__Group__4__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__5();
+            rule__MockingRule__Group__10__Impl();
 
             state._fsp--;
 
@@ -50338,25 +36614,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__4"
+    // $ANTLR end "rule__MockingRule__Group__10"
 
 
-    // $ANTLR start "rule__ManualMock__Group__4__Impl"
-    // InternalTestgeneratorDSL.g:16635:1: rule__ManualMock__Group__4__Impl : ( 'setter' ) ;
-    public final void rule__ManualMock__Group__4__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group__10__Impl"
+    // InternalTestgeneratorDSL.g:12104:1: rule__MockingRule__Group__10__Impl : ( RULE_LIST_CLOSED ) ;
+    public final void rule__MockingRule__Group__10__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16639:1: ( ( 'setter' ) )
-            // InternalTestgeneratorDSL.g:16640:1: ( 'setter' )
+            // InternalTestgeneratorDSL.g:12108:1: ( ( RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:12109:1: ( RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:16640:1: ( 'setter' )
-            // InternalTestgeneratorDSL.g:16641:2: 'setter'
+            // InternalTestgeneratorDSL.g:12109:1: ( RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:12110:2: RULE_LIST_CLOSED
             {
-             before(grammarAccess.getManualMockAccess().getSetterKeyword_4()); 
-            match(input,86,FOLLOW_2); 
-             after(grammarAccess.getManualMockAccess().getSetterKeyword_4()); 
+             before(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
+            match(input,RULE_LIST_CLOSED,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_10()); 
 
             }
 
@@ -50375,21 +36651,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__4__Impl"
+    // $ANTLR end "rule__MockingRule__Group__10__Impl"
 
 
-    // $ANTLR start "rule__ManualMock__Group__5"
-    // InternalTestgeneratorDSL.g:16650:1: rule__ManualMock__Group__5 : rule__ManualMock__Group__5__Impl ;
-    public final void rule__ManualMock__Group__5() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5__0"
+    // InternalTestgeneratorDSL.g:12120:1: rule__MockingRule__Group_5__0 : rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1 ;
+    public final void rule__MockingRule__Group_5__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16654:1: ( rule__ManualMock__Group__5__Impl )
-            // InternalTestgeneratorDSL.g:16655:2: rule__ManualMock__Group__5__Impl
+            // InternalTestgeneratorDSL.g:12124:1: ( rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1 )
+            // InternalTestgeneratorDSL.g:12125:2: rule__MockingRule__Group_5__0__Impl rule__MockingRule__Group_5__1
             {
+            pushFollow(FOLLOW_15);
+            rule__MockingRule__Group_5__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__ManualMock__Group__5__Impl();
+            rule__MockingRule__Group_5__1();
 
             state._fsp--;
 
@@ -50408,35 +36689,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__5"
+    // $ANTLR end "rule__MockingRule__Group_5__0"
 
 
-    // $ANTLR start "rule__ManualMock__Group__5__Impl"
-    // InternalTestgeneratorDSL.g:16661:1: rule__ManualMock__Group__5__Impl : ( ( rule__ManualMock__SetterAssignment_5 ) ) ;
-    public final void rule__ManualMock__Group__5__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5__0__Impl"
+    // InternalTestgeneratorDSL.g:12132:1: rule__MockingRule__Group_5__0__Impl : ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) ) ;
+    public final void rule__MockingRule__Group_5__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16665:1: ( ( ( rule__ManualMock__SetterAssignment_5 ) ) )
-            // InternalTestgeneratorDSL.g:16666:1: ( ( rule__ManualMock__SetterAssignment_5 ) )
+            // InternalTestgeneratorDSL.g:12136:1: ( ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) ) )
+            // InternalTestgeneratorDSL.g:12137:1: ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) )
             {
-            // InternalTestgeneratorDSL.g:16666:1: ( ( rule__ManualMock__SetterAssignment_5 ) )
-            // InternalTestgeneratorDSL.g:16667:2: ( rule__ManualMock__SetterAssignment_5 )
+            // InternalTestgeneratorDSL.g:12137:1: ( ( rule__MockingRule__ComparisonsAssignment_5_0 ) )
+            // InternalTestgeneratorDSL.g:12138:2: ( rule__MockingRule__ComparisonsAssignment_5_0 )
             {
-             before(grammarAccess.getManualMockAccess().getSetterAssignment_5()); 
-            // InternalTestgeneratorDSL.g:16668:2: ( rule__ManualMock__SetterAssignment_5 )
-            // InternalTestgeneratorDSL.g:16668:3: rule__ManualMock__SetterAssignment_5
+             before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); 
+            // InternalTestgeneratorDSL.g:12139:2: ( rule__MockingRule__ComparisonsAssignment_5_0 )
+            // InternalTestgeneratorDSL.g:12139:3: rule__MockingRule__ComparisonsAssignment_5_0
             {
             pushFollow(FOLLOW_2);
-            rule__ManualMock__SetterAssignment_5();
+            rule__MockingRule__ComparisonsAssignment_5_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getManualMockAccess().getSetterAssignment_5()); 
+             after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_0()); 
 
             }
 
@@ -50455,26 +36736,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualMock__Group__5__Impl"
+    // $ANTLR end "rule__MockingRule__Group_5__0__Impl"
 
 
-    // $ANTLR start "rule__StringCompare__Group__0"
-    // InternalTestgeneratorDSL.g:16677:1: rule__StringCompare__Group__0 : rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1 ;
-    public final void rule__StringCompare__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5__1"
+    // InternalTestgeneratorDSL.g:12147:1: rule__MockingRule__Group_5__1 : rule__MockingRule__Group_5__1__Impl ;
+    public final void rule__MockingRule__Group_5__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16681:1: ( rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1 )
-            // InternalTestgeneratorDSL.g:16682:2: rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1
+            // InternalTestgeneratorDSL.g:12151:1: ( rule__MockingRule__Group_5__1__Impl )
+            // InternalTestgeneratorDSL.g:12152:2: rule__MockingRule__Group_5__1__Impl
             {
-            pushFollow(FOLLOW_71);
-            rule__StringCompare__Group__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__StringCompare__Group__1();
+            rule__MockingRule__Group_5__1__Impl();
 
             state._fsp--;
 
@@ -50493,35 +36769,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__0"
+    // $ANTLR end "rule__MockingRule__Group_5__1"
 
 
-    // $ANTLR start "rule__StringCompare__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:16689:1: rule__StringCompare__Group__0__Impl : ( ( rule__StringCompare__KeyAssignment_0 ) ) ;
-    public final void rule__StringCompare__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5__1__Impl"
+    // InternalTestgeneratorDSL.g:12158:1: rule__MockingRule__Group_5__1__Impl : ( ( rule__MockingRule__Group_5_1__0 )* ) ;
+    public final void rule__MockingRule__Group_5__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16693:1: ( ( ( rule__StringCompare__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:16694:1: ( ( rule__StringCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12162:1: ( ( ( rule__MockingRule__Group_5_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:12163:1: ( ( rule__MockingRule__Group_5_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:16694:1: ( ( rule__StringCompare__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:16695:2: ( rule__StringCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12163:1: ( ( rule__MockingRule__Group_5_1__0 )* )
+            // InternalTestgeneratorDSL.g:12164:2: ( rule__MockingRule__Group_5_1__0 )*
             {
-             before(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:16696:2: ( rule__StringCompare__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:16696:3: rule__StringCompare__KeyAssignment_0
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringCompare__KeyAssignment_0();
+             before(grammarAccess.getMockingRuleAccess().getGroup_5_1()); 
+            // InternalTestgeneratorDSL.g:12165:2: ( rule__MockingRule__Group_5_1__0 )*
+            loop72:
+            do {
+                int alt72=2;
+                int LA72_0 = input.LA(1);
 
-            state._fsp--;
+                if ( (LA72_0==RULE_SEPARATOR) ) {
+                    alt72=1;
+                }
 
 
-            }
+                switch (alt72) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:12165:3: rule__MockingRule__Group_5_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__MockingRule__Group_5_1__0();
 
-             after(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); 
+            	    state._fsp--;
+
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop72;
+                }
+            } while (true);
+
+             after(grammarAccess.getMockingRuleAccess().getGroup_5_1()); 
 
             }
 
@@ -50540,26 +36834,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__0__Impl"
+    // $ANTLR end "rule__MockingRule__Group_5__1__Impl"
 
 
-    // $ANTLR start "rule__StringCompare__Group__1"
-    // InternalTestgeneratorDSL.g:16704:1: rule__StringCompare__Group__1 : rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2 ;
-    public final void rule__StringCompare__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5_1__0"
+    // InternalTestgeneratorDSL.g:12174:1: rule__MockingRule__Group_5_1__0 : rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1 ;
+    public final void rule__MockingRule__Group_5_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16708:1: ( rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2 )
-            // InternalTestgeneratorDSL.g:16709:2: rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2
+            // InternalTestgeneratorDSL.g:12178:1: ( rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1 )
+            // InternalTestgeneratorDSL.g:12179:2: rule__MockingRule__Group_5_1__0__Impl rule__MockingRule__Group_5_1__1
             {
-            pushFollow(FOLLOW_7);
-            rule__StringCompare__Group__1__Impl();
+            pushFollow(FOLLOW_4);
+            rule__MockingRule__Group_5_1__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__StringCompare__Group__2();
+            rule__MockingRule__Group_5_1__1();
 
             state._fsp--;
 
@@ -50578,35 +36872,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__1"
+    // $ANTLR end "rule__MockingRule__Group_5_1__0"
 
 
-    // $ANTLR start "rule__StringCompare__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:16716:1: rule__StringCompare__Group__1__Impl : ( ( rule__StringCompare__CompareSymbolAssignment_1 ) ) ;
-    public final void rule__StringCompare__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5_1__0__Impl"
+    // InternalTestgeneratorDSL.g:12186:1: rule__MockingRule__Group_5_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__MockingRule__Group_5_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16720:1: ( ( ( rule__StringCompare__CompareSymbolAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:16721:1: ( ( rule__StringCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12190:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:12191:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:16721:1: ( ( rule__StringCompare__CompareSymbolAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:16722:2: ( rule__StringCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12191:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:12192:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); 
-            // InternalTestgeneratorDSL.g:16723:2: ( rule__StringCompare__CompareSymbolAssignment_1 )
-            // InternalTestgeneratorDSL.g:16723:3: rule__StringCompare__CompareSymbolAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__StringCompare__CompareSymbolAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); 
+             before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0()); 
 
             }
 
@@ -50625,21 +36909,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group_5_1__0__Impl"
 
 
-    // $ANTLR start "rule__StringCompare__Group__2"
-    // InternalTestgeneratorDSL.g:16731:1: rule__StringCompare__Group__2 : rule__StringCompare__Group__2__Impl ;
-    public final void rule__StringCompare__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5_1__1"
+    // InternalTestgeneratorDSL.g:12201:1: rule__MockingRule__Group_5_1__1 : rule__MockingRule__Group_5_1__1__Impl ;
+    public final void rule__MockingRule__Group_5_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16735:1: ( rule__StringCompare__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:16736:2: rule__StringCompare__Group__2__Impl
+            // InternalTestgeneratorDSL.g:12205:1: ( rule__MockingRule__Group_5_1__1__Impl )
+            // InternalTestgeneratorDSL.g:12206:2: rule__MockingRule__Group_5_1__1__Impl
             {
             pushFollow(FOLLOW_2);
-            rule__StringCompare__Group__2__Impl();
+            rule__MockingRule__Group_5_1__1__Impl();
 
             state._fsp--;
 
@@ -50658,35 +36942,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__2"
+    // $ANTLR end "rule__MockingRule__Group_5_1__1"
 
 
-    // $ANTLR start "rule__StringCompare__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:16742:1: rule__StringCompare__Group__2__Impl : ( ( rule__StringCompare__ValueAssignment_2 ) ) ;
-    public final void rule__StringCompare__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_5_1__1__Impl"
+    // InternalTestgeneratorDSL.g:12212:1: rule__MockingRule__Group_5_1__1__Impl : ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) ) ;
+    public final void rule__MockingRule__Group_5_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16746:1: ( ( ( rule__StringCompare__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:16747:1: ( ( rule__StringCompare__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12216:1: ( ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:12217:1: ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:16747:1: ( ( rule__StringCompare__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:16748:2: ( rule__StringCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12217:1: ( ( rule__MockingRule__ComparisonsAssignment_5_1_1 ) )
+            // InternalTestgeneratorDSL.g:12218:2: ( rule__MockingRule__ComparisonsAssignment_5_1_1 )
             {
-             before(grammarAccess.getStringCompareAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:16749:2: ( rule__StringCompare__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:16749:3: rule__StringCompare__ValueAssignment_2
+             before(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); 
+            // InternalTestgeneratorDSL.g:12219:2: ( rule__MockingRule__ComparisonsAssignment_5_1_1 )
+            // InternalTestgeneratorDSL.g:12219:3: rule__MockingRule__ComparisonsAssignment_5_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__StringCompare__ValueAssignment_2();
+            rule__MockingRule__ComparisonsAssignment_5_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getStringCompareAccess().getValueAssignment_2()); 
+             after(grammarAccess.getMockingRuleAccess().getComparisonsAssignment_5_1_1()); 
 
             }
 
@@ -50705,26 +36989,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StringCompare__Group__2__Impl"
+    // $ANTLR end "rule__MockingRule__Group_5_1__1__Impl"
 
 
-    // $ANTLR start "rule__IntCompare__Group__0"
-    // InternalTestgeneratorDSL.g:16758:1: rule__IntCompare__Group__0 : rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1 ;
-    public final void rule__IntCompare__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9__0"
+    // InternalTestgeneratorDSL.g:12228:1: rule__MockingRule__Group_9__0 : rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1 ;
+    public final void rule__MockingRule__Group_9__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16762:1: ( rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1 )
-            // InternalTestgeneratorDSL.g:16763:2: rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1
+            // InternalTestgeneratorDSL.g:12232:1: ( rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1 )
+            // InternalTestgeneratorDSL.g:12233:2: rule__MockingRule__Group_9__0__Impl rule__MockingRule__Group_9__1
             {
-            pushFollow(FOLLOW_72);
-            rule__IntCompare__Group__0__Impl();
+            pushFollow(FOLLOW_15);
+            rule__MockingRule__Group_9__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__IntCompare__Group__1();
+            rule__MockingRule__Group_9__1();
 
             state._fsp--;
 
@@ -50743,35 +37027,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__0"
+    // $ANTLR end "rule__MockingRule__Group_9__0"
 
 
-    // $ANTLR start "rule__IntCompare__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:16770:1: rule__IntCompare__Group__0__Impl : ( ( rule__IntCompare__KeyAssignment_0 ) ) ;
-    public final void rule__IntCompare__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9__0__Impl"
+    // InternalTestgeneratorDSL.g:12240:1: rule__MockingRule__Group_9__0__Impl : ( ( rule__MockingRule__VariablesAssignment_9_0 ) ) ;
+    public final void rule__MockingRule__Group_9__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16774:1: ( ( ( rule__IntCompare__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:16775:1: ( ( rule__IntCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12244:1: ( ( ( rule__MockingRule__VariablesAssignment_9_0 ) ) )
+            // InternalTestgeneratorDSL.g:12245:1: ( ( rule__MockingRule__VariablesAssignment_9_0 ) )
             {
-            // InternalTestgeneratorDSL.g:16775:1: ( ( rule__IntCompare__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:16776:2: ( rule__IntCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12245:1: ( ( rule__MockingRule__VariablesAssignment_9_0 ) )
+            // InternalTestgeneratorDSL.g:12246:2: ( rule__MockingRule__VariablesAssignment_9_0 )
             {
-             before(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:16777:2: ( rule__IntCompare__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:16777:3: rule__IntCompare__KeyAssignment_0
+             before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); 
+            // InternalTestgeneratorDSL.g:12247:2: ( rule__MockingRule__VariablesAssignment_9_0 )
+            // InternalTestgeneratorDSL.g:12247:3: rule__MockingRule__VariablesAssignment_9_0
             {
             pushFollow(FOLLOW_2);
-            rule__IntCompare__KeyAssignment_0();
+            rule__MockingRule__VariablesAssignment_9_0();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); 
+             after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_0()); 
 
             }
 
@@ -50790,26 +37074,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__0__Impl"
+    // $ANTLR end "rule__MockingRule__Group_9__0__Impl"
 
 
-    // $ANTLR start "rule__IntCompare__Group__1"
-    // InternalTestgeneratorDSL.g:16785:1: rule__IntCompare__Group__1 : rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2 ;
-    public final void rule__IntCompare__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9__1"
+    // InternalTestgeneratorDSL.g:12255:1: rule__MockingRule__Group_9__1 : rule__MockingRule__Group_9__1__Impl ;
+    public final void rule__MockingRule__Group_9__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16789:1: ( rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2 )
-            // InternalTestgeneratorDSL.g:16790:2: rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2
+            // InternalTestgeneratorDSL.g:12259:1: ( rule__MockingRule__Group_9__1__Impl )
+            // InternalTestgeneratorDSL.g:12260:2: rule__MockingRule__Group_9__1__Impl
             {
-            pushFollow(FOLLOW_43);
-            rule__IntCompare__Group__1__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__IntCompare__Group__2();
+            rule__MockingRule__Group_9__1__Impl();
 
             state._fsp--;
 
@@ -50828,35 +37107,53 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__1"
+    // $ANTLR end "rule__MockingRule__Group_9__1"
 
 
-    // $ANTLR start "rule__IntCompare__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:16797:1: rule__IntCompare__Group__1__Impl : ( ( rule__IntCompare__CompareSymbolAssignment_1 ) ) ;
-    public final void rule__IntCompare__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9__1__Impl"
+    // InternalTestgeneratorDSL.g:12266:1: rule__MockingRule__Group_9__1__Impl : ( ( rule__MockingRule__Group_9_1__0 )* ) ;
+    public final void rule__MockingRule__Group_9__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16801:1: ( ( ( rule__IntCompare__CompareSymbolAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:16802:1: ( ( rule__IntCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12270:1: ( ( ( rule__MockingRule__Group_9_1__0 )* ) )
+            // InternalTestgeneratorDSL.g:12271:1: ( ( rule__MockingRule__Group_9_1__0 )* )
             {
-            // InternalTestgeneratorDSL.g:16802:1: ( ( rule__IntCompare__CompareSymbolAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:16803:2: ( rule__IntCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12271:1: ( ( rule__MockingRule__Group_9_1__0 )* )
+            // InternalTestgeneratorDSL.g:12272:2: ( rule__MockingRule__Group_9_1__0 )*
             {
-             before(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); 
-            // InternalTestgeneratorDSL.g:16804:2: ( rule__IntCompare__CompareSymbolAssignment_1 )
-            // InternalTestgeneratorDSL.g:16804:3: rule__IntCompare__CompareSymbolAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntCompare__CompareSymbolAssignment_1();
+             before(grammarAccess.getMockingRuleAccess().getGroup_9_1()); 
+            // InternalTestgeneratorDSL.g:12273:2: ( rule__MockingRule__Group_9_1__0 )*
+            loop73:
+            do {
+                int alt73=2;
+                int LA73_0 = input.LA(1);
 
-            state._fsp--;
+                if ( (LA73_0==RULE_SEPARATOR) ) {
+                    alt73=1;
+                }
 
 
-            }
+                switch (alt73) {
+            	case 1 :
+            	    // InternalTestgeneratorDSL.g:12273:3: rule__MockingRule__Group_9_1__0
+            	    {
+            	    pushFollow(FOLLOW_16);
+            	    rule__MockingRule__Group_9_1__0();
+
+            	    state._fsp--;
 
-             after(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); 
+
+            	    }
+            	    break;
+
+            	default :
+            	    break loop73;
+                }
+            } while (true);
+
+             after(grammarAccess.getMockingRuleAccess().getGroup_9_1()); 
 
             }
 
@@ -50875,21 +37172,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__1__Impl"
+    // $ANTLR end "rule__MockingRule__Group_9__1__Impl"
 
 
-    // $ANTLR start "rule__IntCompare__Group__2"
-    // InternalTestgeneratorDSL.g:16812:1: rule__IntCompare__Group__2 : rule__IntCompare__Group__2__Impl ;
-    public final void rule__IntCompare__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9_1__0"
+    // InternalTestgeneratorDSL.g:12282:1: rule__MockingRule__Group_9_1__0 : rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1 ;
+    public final void rule__MockingRule__Group_9_1__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16816:1: ( rule__IntCompare__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:16817:2: rule__IntCompare__Group__2__Impl
+            // InternalTestgeneratorDSL.g:12286:1: ( rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1 )
+            // InternalTestgeneratorDSL.g:12287:2: rule__MockingRule__Group_9_1__0__Impl rule__MockingRule__Group_9_1__1
             {
+            pushFollow(FOLLOW_4);
+            rule__MockingRule__Group_9_1__0__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__IntCompare__Group__2__Impl();
+            rule__MockingRule__Group_9_1__1();
 
             state._fsp--;
 
@@ -50908,35 +37210,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__2"
+    // $ANTLR end "rule__MockingRule__Group_9_1__0"
 
 
-    // $ANTLR start "rule__IntCompare__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:16823:1: rule__IntCompare__Group__2__Impl : ( ( rule__IntCompare__ValueAssignment_2 ) ) ;
-    public final void rule__IntCompare__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9_1__0__Impl"
+    // InternalTestgeneratorDSL.g:12294:1: rule__MockingRule__Group_9_1__0__Impl : ( RULE_SEPARATOR ) ;
+    public final void rule__MockingRule__Group_9_1__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16827:1: ( ( ( rule__IntCompare__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:16828:1: ( ( rule__IntCompare__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12298:1: ( ( RULE_SEPARATOR ) )
+            // InternalTestgeneratorDSL.g:12299:1: ( RULE_SEPARATOR )
             {
-            // InternalTestgeneratorDSL.g:16828:1: ( ( rule__IntCompare__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:16829:2: ( rule__IntCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12299:1: ( RULE_SEPARATOR )
+            // InternalTestgeneratorDSL.g:12300:2: RULE_SEPARATOR
             {
-             before(grammarAccess.getIntCompareAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:16830:2: ( rule__IntCompare__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:16830:3: rule__IntCompare__ValueAssignment_2
-            {
-            pushFollow(FOLLOW_2);
-            rule__IntCompare__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getIntCompareAccess().getValueAssignment_2()); 
+             before(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
+            match(input,RULE_SEPARATOR,FOLLOW_2); 
+             after(grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0()); 
 
             }
 
@@ -50955,26 +37247,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__IntCompare__Group__2__Impl"
+    // $ANTLR end "rule__MockingRule__Group_9_1__0__Impl"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__0"
-    // InternalTestgeneratorDSL.g:16839:1: rule__BooleanCompare__Group__0 : rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1 ;
-    public final void rule__BooleanCompare__Group__0() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9_1__1"
+    // InternalTestgeneratorDSL.g:12309:1: rule__MockingRule__Group_9_1__1 : rule__MockingRule__Group_9_1__1__Impl ;
+    public final void rule__MockingRule__Group_9_1__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16843:1: ( rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1 )
-            // InternalTestgeneratorDSL.g:16844:2: rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1
+            // InternalTestgeneratorDSL.g:12313:1: ( rule__MockingRule__Group_9_1__1__Impl )
+            // InternalTestgeneratorDSL.g:12314:2: rule__MockingRule__Group_9_1__1__Impl
             {
-            pushFollow(FOLLOW_71);
-            rule__BooleanCompare__Group__0__Impl();
-
-            state._fsp--;
-
             pushFollow(FOLLOW_2);
-            rule__BooleanCompare__Group__1();
+            rule__MockingRule__Group_9_1__1__Impl();
 
             state._fsp--;
 
@@ -50993,35 +37280,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__0"
+    // $ANTLR end "rule__MockingRule__Group_9_1__1"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__0__Impl"
-    // InternalTestgeneratorDSL.g:16851:1: rule__BooleanCompare__Group__0__Impl : ( ( rule__BooleanCompare__KeyAssignment_0 ) ) ;
-    public final void rule__BooleanCompare__Group__0__Impl() throws RecognitionException {
+    // $ANTLR start "rule__MockingRule__Group_9_1__1__Impl"
+    // InternalTestgeneratorDSL.g:12320:1: rule__MockingRule__Group_9_1__1__Impl : ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) ) ;
+    public final void rule__MockingRule__Group_9_1__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16855:1: ( ( ( rule__BooleanCompare__KeyAssignment_0 ) ) )
-            // InternalTestgeneratorDSL.g:16856:1: ( ( rule__BooleanCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12324:1: ( ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) ) )
+            // InternalTestgeneratorDSL.g:12325:1: ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) )
             {
-            // InternalTestgeneratorDSL.g:16856:1: ( ( rule__BooleanCompare__KeyAssignment_0 ) )
-            // InternalTestgeneratorDSL.g:16857:2: ( rule__BooleanCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12325:1: ( ( rule__MockingRule__VariablesAssignment_9_1_1 ) )
+            // InternalTestgeneratorDSL.g:12326:2: ( rule__MockingRule__VariablesAssignment_9_1_1 )
             {
-             before(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); 
-            // InternalTestgeneratorDSL.g:16858:2: ( rule__BooleanCompare__KeyAssignment_0 )
-            // InternalTestgeneratorDSL.g:16858:3: rule__BooleanCompare__KeyAssignment_0
+             before(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); 
+            // InternalTestgeneratorDSL.g:12327:2: ( rule__MockingRule__VariablesAssignment_9_1_1 )
+            // InternalTestgeneratorDSL.g:12327:3: rule__MockingRule__VariablesAssignment_9_1_1
             {
             pushFollow(FOLLOW_2);
-            rule__BooleanCompare__KeyAssignment_0();
+            rule__MockingRule__VariablesAssignment_9_1_1();
 
             state._fsp--;
 
 
             }
 
-             after(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); 
+             after(grammarAccess.getMockingRuleAccess().getVariablesAssignment_9_1_1()); 
 
             }
 
@@ -51040,26 +37327,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__0__Impl"
+    // $ANTLR end "rule__MockingRule__Group_9_1__1__Impl"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__1"
-    // InternalTestgeneratorDSL.g:16866:1: rule__BooleanCompare__Group__1 : rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2 ;
-    public final void rule__BooleanCompare__Group__1() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__0"
+    // InternalTestgeneratorDSL.g:12336:1: rule__ManualMock__Group__0 : rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1 ;
+    public final void rule__ManualMock__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16870:1: ( rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2 )
-            // InternalTestgeneratorDSL.g:16871:2: rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2
+            // InternalTestgeneratorDSL.g:12340:1: ( rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1 )
+            // InternalTestgeneratorDSL.g:12341:2: rule__ManualMock__Group__0__Impl rule__ManualMock__Group__1
             {
-            pushFollow(FOLLOW_45);
-            rule__BooleanCompare__Group__1__Impl();
+            pushFollow(FOLLOW_67);
+            rule__ManualMock__Group__0__Impl();
 
             state._fsp--;
 
             pushFollow(FOLLOW_2);
-            rule__BooleanCompare__Group__2();
+            rule__ManualMock__Group__1();
 
             state._fsp--;
 
@@ -51078,35 +37365,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__1"
+    // $ANTLR end "rule__ManualMock__Group__0"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__1__Impl"
-    // InternalTestgeneratorDSL.g:16878:1: rule__BooleanCompare__Group__1__Impl : ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) ) ;
-    public final void rule__BooleanCompare__Group__1__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:12348:1: rule__ManualMock__Group__0__Impl : ( 'with' ) ;
+    public final void rule__ManualMock__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16882:1: ( ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) ) )
-            // InternalTestgeneratorDSL.g:16883:1: ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12352:1: ( ( 'with' ) )
+            // InternalTestgeneratorDSL.g:12353:1: ( 'with' )
             {
-            // InternalTestgeneratorDSL.g:16883:1: ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) )
-            // InternalTestgeneratorDSL.g:16884:2: ( rule__BooleanCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12353:1: ( 'with' )
+            // InternalTestgeneratorDSL.g:12354:2: 'with'
             {
-             before(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); 
-            // InternalTestgeneratorDSL.g:16885:2: ( rule__BooleanCompare__CompareSymbolAssignment_1 )
-            // InternalTestgeneratorDSL.g:16885:3: rule__BooleanCompare__CompareSymbolAssignment_1
-            {
-            pushFollow(FOLLOW_2);
-            rule__BooleanCompare__CompareSymbolAssignment_1();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); 
+             before(grammarAccess.getManualMockAccess().getWithKeyword_0()); 
+            match(input,29,FOLLOW_2); 
+             after(grammarAccess.getManualMockAccess().getWithKeyword_0()); 
 
             }
 
@@ -51125,21 +37402,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__1__Impl"
+    // $ANTLR end "rule__ManualMock__Group__0__Impl"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__2"
-    // InternalTestgeneratorDSL.g:16893:1: rule__BooleanCompare__Group__2 : rule__BooleanCompare__Group__2__Impl ;
-    public final void rule__BooleanCompare__Group__2() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__1"
+    // InternalTestgeneratorDSL.g:12363:1: rule__ManualMock__Group__1 : rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2 ;
+    public final void rule__ManualMock__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16897:1: ( rule__BooleanCompare__Group__2__Impl )
-            // InternalTestgeneratorDSL.g:16898:2: rule__BooleanCompare__Group__2__Impl
+            // InternalTestgeneratorDSL.g:12367:1: ( rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2 )
+            // InternalTestgeneratorDSL.g:12368:2: rule__ManualMock__Group__1__Impl rule__ManualMock__Group__2
             {
+            pushFollow(FOLLOW_7);
+            rule__ManualMock__Group__1__Impl();
+
+            state._fsp--;
+
             pushFollow(FOLLOW_2);
-            rule__BooleanCompare__Group__2__Impl();
+            rule__ManualMock__Group__2();
 
             state._fsp--;
 
@@ -51158,35 +37440,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__2"
+    // $ANTLR end "rule__ManualMock__Group__1"
 
 
-    // $ANTLR start "rule__BooleanCompare__Group__2__Impl"
-    // InternalTestgeneratorDSL.g:16904:1: rule__BooleanCompare__Group__2__Impl : ( ( rule__BooleanCompare__ValueAssignment_2 ) ) ;
-    public final void rule__BooleanCompare__Group__2__Impl() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:12375:1: rule__ManualMock__Group__1__Impl : ( 'manual' ) ;
+    public final void rule__ManualMock__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16908:1: ( ( ( rule__BooleanCompare__ValueAssignment_2 ) ) )
-            // InternalTestgeneratorDSL.g:16909:1: ( ( rule__BooleanCompare__ValueAssignment_2 ) )
-            {
-            // InternalTestgeneratorDSL.g:16909:1: ( ( rule__BooleanCompare__ValueAssignment_2 ) )
-            // InternalTestgeneratorDSL.g:16910:2: ( rule__BooleanCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12379:1: ( ( 'manual' ) )
+            // InternalTestgeneratorDSL.g:12380:1: ( 'manual' )
             {
-             before(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); 
-            // InternalTestgeneratorDSL.g:16911:2: ( rule__BooleanCompare__ValueAssignment_2 )
-            // InternalTestgeneratorDSL.g:16911:3: rule__BooleanCompare__ValueAssignment_2
+            // InternalTestgeneratorDSL.g:12380:1: ( 'manual' )
+            // InternalTestgeneratorDSL.g:12381:2: 'manual'
             {
-            pushFollow(FOLLOW_2);
-            rule__BooleanCompare__ValueAssignment_2();
-
-            state._fsp--;
-
-
-            }
-
-             after(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); 
+             before(grammarAccess.getManualMockAccess().getManualKeyword_1()); 
+            match(input,84,FOLLOW_2); 
+             after(grammarAccess.getManualMockAccess().getManualKeyword_1()); 
 
             }
 
@@ -51205,31 +37477,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BooleanCompare__Group__2__Impl"
+    // $ANTLR end "rule__ManualMock__Group__1__Impl"
 
 
-    // $ANTLR start "rule__Model__DeclarationsAssignment"
-    // InternalTestgeneratorDSL.g:16920:1: rule__Model__DeclarationsAssignment : ( ruleDeclaration ) ;
-    public final void rule__Model__DeclarationsAssignment() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__2"
+    // InternalTestgeneratorDSL.g:12390:1: rule__ManualMock__Group__2 : rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3 ;
+    public final void rule__ManualMock__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16924:1: ( ( ruleDeclaration ) )
-            // InternalTestgeneratorDSL.g:16925:2: ( ruleDeclaration )
-            {
-            // InternalTestgeneratorDSL.g:16925:2: ( ruleDeclaration )
-            // InternalTestgeneratorDSL.g:16926:3: ruleDeclaration
+            // InternalTestgeneratorDSL.g:12394:1: ( rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3 )
+            // InternalTestgeneratorDSL.g:12395:2: rule__ManualMock__Group__2__Impl rule__ManualMock__Group__3
             {
-             before(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); 
-            pushFollow(FOLLOW_2);
-            ruleDeclaration();
+            pushFollow(FOLLOW_47);
+            rule__ManualMock__Group__2__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); 
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__Group__3();
 
-            }
+            state._fsp--;
 
 
             }
@@ -51246,25 +37515,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__Model__DeclarationsAssignment"
+    // $ANTLR end "rule__ManualMock__Group__2"
 
 
-    // $ANTLR start "rule__BPMNDiagram__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:16935:1: rule__BPMNDiagram__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__BPMNDiagram__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:12402:1: rule__ManualMock__Group__2__Impl : ( ( rule__ManualMock__ServiceNameAssignment_2 ) ) ;
+    public final void rule__ManualMock__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16939:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:16940:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12406:1: ( ( ( rule__ManualMock__ServiceNameAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:12407:1: ( ( rule__ManualMock__ServiceNameAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:16940:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:16941:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12407:1: ( ( rule__ManualMock__ServiceNameAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12408:2: ( rule__ManualMock__ServiceNameAssignment_2 )
             {
-             before(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); 
+             before(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); 
+            // InternalTestgeneratorDSL.g:12409:2: ( rule__ManualMock__ServiceNameAssignment_2 )
+            // InternalTestgeneratorDSL.g:12409:3: rule__ManualMock__ServiceNameAssignment_2
+            {
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__ServiceNameAssignment_2();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getManualMockAccess().getServiceNameAssignment_2()); 
 
             }
 
@@ -51283,27 +37562,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__NameAssignment_1"
+    // $ANTLR end "rule__ManualMock__Group__2__Impl"
 
 
-    // $ANTLR start "rule__BPMNDiagram__TestpackageAssignment_4"
-    // InternalTestgeneratorDSL.g:16950:1: rule__BPMNDiagram__TestpackageAssignment_4 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__TestpackageAssignment_4() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__3"
+    // InternalTestgeneratorDSL.g:12417:1: rule__ManualMock__Group__3 : rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4 ;
+    public final void rule__ManualMock__Group__3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16954:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:16955:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12421:1: ( rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4 )
+            // InternalTestgeneratorDSL.g:12422:2: rule__ManualMock__Group__3__Impl rule__ManualMock__Group__4
             {
-            // InternalTestgeneratorDSL.g:16955:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:16956:3: RULE_STRING
-            {
-             before(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); 
+            pushFollow(FOLLOW_68);
+            rule__ManualMock__Group__3__Impl();
 
-            }
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__Group__4();
+
+            state._fsp--;
 
 
             }
@@ -51320,25 +37600,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__TestpackageAssignment_4"
+    // $ANTLR end "rule__ManualMock__Group__3"
 
 
-    // $ANTLR start "rule__BPMNDiagram__BpmnAssignment_7"
-    // InternalTestgeneratorDSL.g:16965:1: rule__BPMNDiagram__BpmnAssignment_7 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__BpmnAssignment_7() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__3__Impl"
+    // InternalTestgeneratorDSL.g:12429:1: rule__ManualMock__Group__3__Impl : ( 'by' ) ;
+    public final void rule__ManualMock__Group__3__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16969:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:16970:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12433:1: ( ( 'by' ) )
+            // InternalTestgeneratorDSL.g:12434:1: ( 'by' )
             {
-            // InternalTestgeneratorDSL.g:16970:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:16971:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12434:1: ( 'by' )
+            // InternalTestgeneratorDSL.g:12435:2: 'by'
             {
-             before(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); 
+             before(grammarAccess.getManualMockAccess().getByKeyword_3()); 
+            match(input,62,FOLLOW_2); 
+             after(grammarAccess.getManualMockAccess().getByKeyword_3()); 
 
             }
 
@@ -51357,27 +37637,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__BpmnAssignment_7"
+    // $ANTLR end "rule__ManualMock__Group__3__Impl"
 
 
-    // $ANTLR start "rule__BPMNDiagram__KeyAssignment_10"
-    // InternalTestgeneratorDSL.g:16980:1: rule__BPMNDiagram__KeyAssignment_10 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__KeyAssignment_10() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__4"
+    // InternalTestgeneratorDSL.g:12444:1: rule__ManualMock__Group__4 : rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5 ;
+    public final void rule__ManualMock__Group__4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16984:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:16985:2: ( RULE_STRING )
-            {
-            // InternalTestgeneratorDSL.g:16985:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:16986:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12448:1: ( rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5 )
+            // InternalTestgeneratorDSL.g:12449:2: rule__ManualMock__Group__4__Impl rule__ManualMock__Group__5
             {
-             before(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); 
+            pushFollow(FOLLOW_7);
+            rule__ManualMock__Group__4__Impl();
 
-            }
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__Group__5();
+
+            state._fsp--;
 
 
             }
@@ -51394,25 +37675,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__KeyAssignment_10"
+    // $ANTLR end "rule__ManualMock__Group__4"
 
 
-    // $ANTLR start "rule__BPMNDiagram__DmnAssignment_11_4_0"
-    // InternalTestgeneratorDSL.g:16995:1: rule__BPMNDiagram__DmnAssignment_11_4_0 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__DmnAssignment_11_4_0() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__4__Impl"
+    // InternalTestgeneratorDSL.g:12456:1: rule__ManualMock__Group__4__Impl : ( 'setter' ) ;
+    public final void rule__ManualMock__Group__4__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:16999:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17000:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12460:1: ( ( 'setter' ) )
+            // InternalTestgeneratorDSL.g:12461:1: ( 'setter' )
             {
-            // InternalTestgeneratorDSL.g:17000:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17001:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12461:1: ( 'setter' )
+            // InternalTestgeneratorDSL.g:12462:2: 'setter'
             {
-             before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); 
+             before(grammarAccess.getManualMockAccess().getSetterKeyword_4()); 
+            match(input,85,FOLLOW_2); 
+             after(grammarAccess.getManualMockAccess().getSetterKeyword_4()); 
 
             }
 
@@ -51431,27 +37712,23 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__DmnAssignment_11_4_0"
+    // $ANTLR end "rule__ManualMock__Group__4__Impl"
 
 
-    // $ANTLR start "rule__BPMNDiagram__DmnAssignment_11_4_1_1"
-    // InternalTestgeneratorDSL.g:17010:1: rule__BPMNDiagram__DmnAssignment_11_4_1_1 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__DmnAssignment_11_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__5"
+    // InternalTestgeneratorDSL.g:12471:1: rule__ManualMock__Group__5 : rule__ManualMock__Group__5__Impl ;
+    public final void rule__ManualMock__Group__5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17014:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17015:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12475:1: ( rule__ManualMock__Group__5__Impl )
+            // InternalTestgeneratorDSL.g:12476:2: rule__ManualMock__Group__5__Impl
             {
-            // InternalTestgeneratorDSL.g:17015:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17016:3: RULE_STRING
-            {
-             before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); 
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__Group__5__Impl();
 
-            }
+            state._fsp--;
 
 
             }
@@ -51468,25 +37745,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__DmnAssignment_11_4_1_1"
+    // $ANTLR end "rule__ManualMock__Group__5"
 
 
-    // $ANTLR start "rule__BPMNDiagram__EmbeddedAssignment_12_4_0"
-    // InternalTestgeneratorDSL.g:17025:1: rule__BPMNDiagram__EmbeddedAssignment_12_4_0 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__EmbeddedAssignment_12_4_0() throws RecognitionException {
+    // $ANTLR start "rule__ManualMock__Group__5__Impl"
+    // InternalTestgeneratorDSL.g:12482:1: rule__ManualMock__Group__5__Impl : ( ( rule__ManualMock__SetterAssignment_5 ) ) ;
+    public final void rule__ManualMock__Group__5__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17029:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17030:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12486:1: ( ( ( rule__ManualMock__SetterAssignment_5 ) ) )
+            // InternalTestgeneratorDSL.g:12487:1: ( ( rule__ManualMock__SetterAssignment_5 ) )
             {
-            // InternalTestgeneratorDSL.g:17030:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17031:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12487:1: ( ( rule__ManualMock__SetterAssignment_5 ) )
+            // InternalTestgeneratorDSL.g:12488:2: ( rule__ManualMock__SetterAssignment_5 )
             {
-             before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); 
+             before(grammarAccess.getManualMockAccess().getSetterAssignment_5()); 
+            // InternalTestgeneratorDSL.g:12489:2: ( rule__ManualMock__SetterAssignment_5 )
+            // InternalTestgeneratorDSL.g:12489:3: rule__ManualMock__SetterAssignment_5
+            {
+            pushFollow(FOLLOW_2);
+            rule__ManualMock__SetterAssignment_5();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getManualMockAccess().getSetterAssignment_5()); 
 
             }
 
@@ -51505,27 +37792,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__EmbeddedAssignment_12_4_0"
+    // $ANTLR end "rule__ManualMock__Group__5__Impl"
 
 
-    // $ANTLR start "rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1"
-    // InternalTestgeneratorDSL.g:17040:1: rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 : ( RULE_STRING ) ;
-    public final void rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__0"
+    // InternalTestgeneratorDSL.g:12498:1: rule__StringCompare__Group__0 : rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1 ;
+    public final void rule__StringCompare__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17044:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17045:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12502:1: ( rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1 )
+            // InternalTestgeneratorDSL.g:12503:2: rule__StringCompare__Group__0__Impl rule__StringCompare__Group__1
             {
-            // InternalTestgeneratorDSL.g:17045:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17046:3: RULE_STRING
-            {
-             before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); 
+            pushFollow(FOLLOW_69);
+            rule__StringCompare__Group__0__Impl();
 
-            }
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__StringCompare__Group__1();
+
+            state._fsp--;
 
 
             }
@@ -51542,33 +37830,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1"
+    // $ANTLR end "rule__StringCompare__Group__0"
 
 
-    // $ANTLR start "rule__BPMNReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:17055:1: rule__BPMNReference__RefAssignment : ( ( RULE_ID ) ) ;
-    public final void rule__BPMNReference__RefAssignment() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:12510:1: rule__StringCompare__Group__0__Impl : ( ( rule__StringCompare__KeyAssignment_0 ) ) ;
+    public final void rule__StringCompare__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17059:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:17060:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12514:1: ( ( ( rule__StringCompare__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:12515:1: ( ( rule__StringCompare__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:17060:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17061:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12515:1: ( ( rule__StringCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12516:2: ( rule__StringCompare__KeyAssignment_0 )
             {
-             before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:17062:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17063:4: RULE_ID
+             before(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:12517:2: ( rule__StringCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12517:3: rule__StringCompare__KeyAssignment_0
             {
-             before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); 
+            pushFollow(FOLLOW_2);
+            rule__StringCompare__KeyAssignment_0();
+
+            state._fsp--;
+
 
             }
 
-             after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); 
+             after(grammarAccess.getStringCompareAccess().getKeyAssignment_0()); 
 
             }
 
@@ -51587,27 +37877,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BPMNReference__RefAssignment"
+    // $ANTLR end "rule__StringCompare__Group__0__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17074:1: rule__StartFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__StartFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__1"
+    // InternalTestgeneratorDSL.g:12525:1: rule__StringCompare__Group__1 : rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2 ;
+    public final void rule__StringCompare__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17078:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17079:2: ( RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:17079:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17080:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12529:1: ( rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2 )
+            // InternalTestgeneratorDSL.g:12530:2: rule__StringCompare__Group__1__Impl rule__StringCompare__Group__2
             {
-             before(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            pushFollow(FOLLOW_7);
+            rule__StringCompare__Group__1__Impl();
 
-            }
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__StringCompare__Group__2();
+
+            state._fsp--;
 
 
             }
@@ -51624,29 +37915,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__StringCompare__Group__1"
 
 
-    // $ANTLR start "rule__StartFlowElement__HardcodedInputsAssignment_4_5_0"
-    // InternalTestgeneratorDSL.g:17089:1: rule__StartFlowElement__HardcodedInputsAssignment_4_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__StartFlowElement__HardcodedInputsAssignment_4_5_0() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:12537:1: rule__StringCompare__Group__1__Impl : ( ( rule__StringCompare__CompareSymbolAssignment_1 ) ) ;
+    public final void rule__StringCompare__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17093:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17094:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12541:1: ( ( ( rule__StringCompare__CompareSymbolAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:12542:1: ( ( rule__StringCompare__CompareSymbolAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:17094:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17095:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12542:1: ( ( rule__StringCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12543:2: ( rule__StringCompare__CompareSymbolAssignment_1 )
+            {
+             before(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); 
+            // InternalTestgeneratorDSL.g:12544:2: ( rule__StringCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12544:3: rule__StringCompare__CompareSymbolAssignment_1
             {
-             before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            rule__StringCompare__CompareSymbolAssignment_1();
 
             state._fsp--;
 
-             after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
+
+            }
+
+             after(grammarAccess.getStringCompareAccess().getCompareSymbolAssignment_1()); 
 
             }
 
@@ -51665,32 +37962,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__HardcodedInputsAssignment_4_5_0"
+    // $ANTLR end "rule__StringCompare__Group__1__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1"
-    // InternalTestgeneratorDSL.g:17104:1: rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__2"
+    // InternalTestgeneratorDSL.g:12552:1: rule__StringCompare__Group__2 : rule__StringCompare__Group__2__Impl ;
+    public final void rule__StringCompare__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17108:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17109:2: ( ruleVariableDeclaration )
-            {
-            // InternalTestgeneratorDSL.g:17109:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17110:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12556:1: ( rule__StringCompare__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:12557:2: rule__StringCompare__Group__2__Impl
             {
-             before(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            rule__StringCompare__Group__2__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
-
-            }
-
 
             }
 
@@ -51706,29 +37995,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__HardcodedInputsAssignment_4_5_1_1"
+    // $ANTLR end "rule__StringCompare__Group__2"
 
 
-    // $ANTLR start "rule__StartFlowElement__StartVariablesAssignment_5_4_0"
-    // InternalTestgeneratorDSL.g:17119:1: rule__StartFlowElement__StartVariablesAssignment_5_4_0 : ( ruleVariableReference ) ;
-    public final void rule__StartFlowElement__StartVariablesAssignment_5_4_0() throws RecognitionException {
+    // $ANTLR start "rule__StringCompare__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:12563:1: rule__StringCompare__Group__2__Impl : ( ( rule__StringCompare__ValueAssignment_2 ) ) ;
+    public final void rule__StringCompare__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17123:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17124:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12567:1: ( ( ( rule__StringCompare__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:12568:1: ( ( rule__StringCompare__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:17124:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17125:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12568:1: ( ( rule__StringCompare__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12569:2: ( rule__StringCompare__ValueAssignment_2 )
+            {
+             before(grammarAccess.getStringCompareAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:12570:2: ( rule__StringCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12570:3: rule__StringCompare__ValueAssignment_2
             {
-             before(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            rule__StringCompare__ValueAssignment_2();
 
             state._fsp--;
 
-             after(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
+
+            }
+
+             after(grammarAccess.getStringCompareAccess().getValueAssignment_2()); 
 
             }
 
@@ -51747,31 +38042,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__StartVariablesAssignment_5_4_0"
+    // $ANTLR end "rule__StringCompare__Group__2__Impl"
 
 
-    // $ANTLR start "rule__StartFlowElement__StartVariablesAssignment_5_4_1_1"
-    // InternalTestgeneratorDSL.g:17134:1: rule__StartFlowElement__StartVariablesAssignment_5_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__StartFlowElement__StartVariablesAssignment_5_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__0"
+    // InternalTestgeneratorDSL.g:12579:1: rule__IntCompare__Group__0 : rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1 ;
+    public final void rule__IntCompare__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17138:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17139:2: ( ruleVariableReference )
-            {
-            // InternalTestgeneratorDSL.g:17139:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17140:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12583:1: ( rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1 )
+            // InternalTestgeneratorDSL.g:12584:2: rule__IntCompare__Group__0__Impl rule__IntCompare__Group__1
             {
-             before(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            pushFollow(FOLLOW_70);
+            rule__IntCompare__Group__0__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
+            pushFollow(FOLLOW_2);
+            rule__IntCompare__Group__1();
 
-            }
+            state._fsp--;
 
 
             }
@@ -51788,25 +38080,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__StartFlowElement__StartVariablesAssignment_5_4_1_1"
+    // $ANTLR end "rule__IntCompare__Group__0"
 
 
-    // $ANTLR start "rule__EndFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17149:1: rule__EndFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__EndFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:12591:1: rule__IntCompare__Group__0__Impl : ( ( rule__IntCompare__KeyAssignment_0 ) ) ;
+    public final void rule__IntCompare__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17153:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17154:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12595:1: ( ( ( rule__IntCompare__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:12596:1: ( ( rule__IntCompare__KeyAssignment_0 ) )
             {
-            // InternalTestgeneratorDSL.g:17154:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17155:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12596:1: ( ( rule__IntCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12597:2: ( rule__IntCompare__KeyAssignment_0 )
             {
-             before(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             before(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:12598:2: ( rule__IntCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12598:3: rule__IntCompare__KeyAssignment_0
+            {
+            pushFollow(FOLLOW_2);
+            rule__IntCompare__KeyAssignment_0();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getIntCompareAccess().getKeyAssignment_0()); 
 
             }
 
@@ -51825,27 +38127,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__EndFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__IntCompare__Group__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17164:1: rule__UserTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__UserTaskFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__1"
+    // InternalTestgeneratorDSL.g:12606:1: rule__IntCompare__Group__1 : rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2 ;
+    public final void rule__IntCompare__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17168:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17169:2: ( RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:17169:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17170:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12610:1: ( rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2 )
+            // InternalTestgeneratorDSL.g:12611:2: rule__IntCompare__Group__1__Impl rule__IntCompare__Group__2
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            pushFollow(FOLLOW_42);
+            rule__IntCompare__Group__1__Impl();
 
-            }
+            state._fsp--;
+
+            pushFollow(FOLLOW_2);
+            rule__IntCompare__Group__2();
+
+            state._fsp--;
 
 
             }
@@ -51862,29 +38165,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__IntCompare__Group__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0"
-    // InternalTestgeneratorDSL.g:17179:1: rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:12618:1: rule__IntCompare__Group__1__Impl : ( ( rule__IntCompare__CompareSymbolAssignment_1 ) ) ;
+    public final void rule__IntCompare__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17183:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17184:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12622:1: ( ( ( rule__IntCompare__CompareSymbolAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:12623:1: ( ( rule__IntCompare__CompareSymbolAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:17184:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17185:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12623:1: ( ( rule__IntCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12624:2: ( rule__IntCompare__CompareSymbolAssignment_1 )
+            {
+             before(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); 
+            // InternalTestgeneratorDSL.g:12625:2: ( rule__IntCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12625:3: rule__IntCompare__CompareSymbolAssignment_1
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            rule__IntCompare__CompareSymbolAssignment_1();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
+
+            }
+
+             after(grammarAccess.getIntCompareAccess().getCompareSymbolAssignment_1()); 
 
             }
 
@@ -51903,32 +38212,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_0"
+    // $ANTLR end "rule__IntCompare__Group__1__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
-    // InternalTestgeneratorDSL.g:17194:1: rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__2"
+    // InternalTestgeneratorDSL.g:12633:1: rule__IntCompare__Group__2 : rule__IntCompare__Group__2__Impl ;
+    public final void rule__IntCompare__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17198:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17199:2: ( ruleVariableDeclaration )
-            {
-            // InternalTestgeneratorDSL.g:17199:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17200:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12637:1: ( rule__IntCompare__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:12638:2: rule__IntCompare__Group__2__Impl
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            rule__IntCompare__Group__2__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
-
-            }
-
 
             }
 
@@ -51944,29 +38245,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
+    // $ANTLR end "rule__IntCompare__Group__2"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0"
-    // InternalTestgeneratorDSL.g:17209:1: rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0 : ( ruleVariableReference ) ;
-    public final void rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0() throws RecognitionException {
+    // $ANTLR start "rule__IntCompare__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:12644:1: rule__IntCompare__Group__2__Impl : ( ( rule__IntCompare__ValueAssignment_2 ) ) ;
+    public final void rule__IntCompare__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17213:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17214:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12648:1: ( ( ( rule__IntCompare__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:12649:1: ( ( rule__IntCompare__ValueAssignment_2 ) )
             {
-            // InternalTestgeneratorDSL.g:17214:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17215:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12649:1: ( ( rule__IntCompare__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12650:2: ( rule__IntCompare__ValueAssignment_2 )
+            {
+             before(grammarAccess.getIntCompareAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:12651:2: ( rule__IntCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12651:3: rule__IntCompare__ValueAssignment_2
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            rule__IntCompare__ValueAssignment_2();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
+
+            }
+
+             after(grammarAccess.getIntCompareAccess().getValueAssignment_2()); 
 
             }
 
@@ -51985,31 +38292,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_0"
+    // $ANTLR end "rule__IntCompare__Group__2__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1"
-    // InternalTestgeneratorDSL.g:17224:1: rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__0"
+    // InternalTestgeneratorDSL.g:12660:1: rule__BooleanCompare__Group__0 : rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1 ;
+    public final void rule__BooleanCompare__Group__0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17228:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17229:2: ( ruleVariableReference )
-            {
-            // InternalTestgeneratorDSL.g:17229:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17230:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12664:1: ( rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1 )
+            // InternalTestgeneratorDSL.g:12665:2: rule__BooleanCompare__Group__0__Impl rule__BooleanCompare__Group__1
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            pushFollow(FOLLOW_69);
+            rule__BooleanCompare__Group__0__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
+            pushFollow(FOLLOW_2);
+            rule__BooleanCompare__Group__1();
 
-            }
+            state._fsp--;
 
 
             }
@@ -52026,29 +38330,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__InputVariablesAssignment_5_4_1_1"
+    // $ANTLR end "rule__BooleanCompare__Group__0"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0"
-    // InternalTestgeneratorDSL.g:17239:1: rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0 : ( ruleVariableReference ) ;
-    public final void rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__0__Impl"
+    // InternalTestgeneratorDSL.g:12672:1: rule__BooleanCompare__Group__0__Impl : ( ( rule__BooleanCompare__KeyAssignment_0 ) ) ;
+    public final void rule__BooleanCompare__Group__0__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17243:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17244:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12676:1: ( ( ( rule__BooleanCompare__KeyAssignment_0 ) ) )
+            // InternalTestgeneratorDSL.g:12677:1: ( ( rule__BooleanCompare__KeyAssignment_0 ) )
+            {
+            // InternalTestgeneratorDSL.g:12677:1: ( ( rule__BooleanCompare__KeyAssignment_0 ) )
+            // InternalTestgeneratorDSL.g:12678:2: ( rule__BooleanCompare__KeyAssignment_0 )
             {
-            // InternalTestgeneratorDSL.g:17244:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17245:3: ruleVariableReference
+             before(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); 
+            // InternalTestgeneratorDSL.g:12679:2: ( rule__BooleanCompare__KeyAssignment_0 )
+            // InternalTestgeneratorDSL.g:12679:3: rule__BooleanCompare__KeyAssignment_0
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            rule__BooleanCompare__KeyAssignment_0();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+
+            }
+
+             after(grammarAccess.getBooleanCompareAccess().getKeyAssignment_0()); 
 
             }
 
@@ -52067,31 +38377,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_0"
+    // $ANTLR end "rule__BooleanCompare__Group__0__Impl"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
-    // InternalTestgeneratorDSL.g:17254:1: rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__1"
+    // InternalTestgeneratorDSL.g:12687:1: rule__BooleanCompare__Group__1 : rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2 ;
+    public final void rule__BooleanCompare__Group__1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17258:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17259:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12691:1: ( rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2 )
+            // InternalTestgeneratorDSL.g:12692:2: rule__BooleanCompare__Group__1__Impl rule__BooleanCompare__Group__2
             {
-            // InternalTestgeneratorDSL.g:17259:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17260:3: ruleVariableReference
-            {
-             before(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            pushFollow(FOLLOW_44);
+            rule__BooleanCompare__Group__1__Impl();
 
             state._fsp--;
 
-             after(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
+            pushFollow(FOLLOW_2);
+            rule__BooleanCompare__Group__2();
 
-            }
+            state._fsp--;
 
 
             }
@@ -52108,25 +38415,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
+    // $ANTLR end "rule__BooleanCompare__Group__1"
 
 
-    // $ANTLR start "rule__UserTaskFlowElement__LabelAssignment_7_3"
-    // InternalTestgeneratorDSL.g:17269:1: rule__UserTaskFlowElement__LabelAssignment_7_3 : ( RULE_STRING ) ;
-    public final void rule__UserTaskFlowElement__LabelAssignment_7_3() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__1__Impl"
+    // InternalTestgeneratorDSL.g:12699:1: rule__BooleanCompare__Group__1__Impl : ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) ) ;
+    public final void rule__BooleanCompare__Group__1__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17273:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17274:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12703:1: ( ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) ) )
+            // InternalTestgeneratorDSL.g:12704:1: ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) )
             {
-            // InternalTestgeneratorDSL.g:17274:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17275:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12704:1: ( ( rule__BooleanCompare__CompareSymbolAssignment_1 ) )
+            // InternalTestgeneratorDSL.g:12705:2: ( rule__BooleanCompare__CompareSymbolAssignment_1 )
             {
-             before(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
+             before(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); 
+            // InternalTestgeneratorDSL.g:12706:2: ( rule__BooleanCompare__CompareSymbolAssignment_1 )
+            // InternalTestgeneratorDSL.g:12706:3: rule__BooleanCompare__CompareSymbolAssignment_1
+            {
+            pushFollow(FOLLOW_2);
+            rule__BooleanCompare__CompareSymbolAssignment_1();
+
+            state._fsp--;
+
+
+            }
+
+             after(grammarAccess.getBooleanCompareAccess().getCompareSymbolAssignment_1()); 
 
             }
 
@@ -52145,27 +38462,23 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__UserTaskFlowElement__LabelAssignment_7_3"
+    // $ANTLR end "rule__BooleanCompare__Group__1__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17284:1: rule__ManualTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__ManualTaskFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__2"
+    // InternalTestgeneratorDSL.g:12714:1: rule__BooleanCompare__Group__2 : rule__BooleanCompare__Group__2__Impl ;
+    public final void rule__BooleanCompare__Group__2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17288:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17289:2: ( RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:17289:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17290:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12718:1: ( rule__BooleanCompare__Group__2__Impl )
+            // InternalTestgeneratorDSL.g:12719:2: rule__BooleanCompare__Group__2__Impl
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            pushFollow(FOLLOW_2);
+            rule__BooleanCompare__Group__2__Impl();
 
-            }
+            state._fsp--;
 
 
             }
@@ -52182,29 +38495,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__BooleanCompare__Group__2"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0"
-    // InternalTestgeneratorDSL.g:17299:1: rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0() throws RecognitionException {
+    // $ANTLR start "rule__BooleanCompare__Group__2__Impl"
+    // InternalTestgeneratorDSL.g:12725:1: rule__BooleanCompare__Group__2__Impl : ( ( rule__BooleanCompare__ValueAssignment_2 ) ) ;
+    public final void rule__BooleanCompare__Group__2__Impl() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17303:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17304:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12729:1: ( ( ( rule__BooleanCompare__ValueAssignment_2 ) ) )
+            // InternalTestgeneratorDSL.g:12730:1: ( ( rule__BooleanCompare__ValueAssignment_2 ) )
+            {
+            // InternalTestgeneratorDSL.g:12730:1: ( ( rule__BooleanCompare__ValueAssignment_2 ) )
+            // InternalTestgeneratorDSL.g:12731:2: ( rule__BooleanCompare__ValueAssignment_2 )
             {
-            // InternalTestgeneratorDSL.g:17304:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17305:3: ruleVariableDeclaration
+             before(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); 
+            // InternalTestgeneratorDSL.g:12732:2: ( rule__BooleanCompare__ValueAssignment_2 )
+            // InternalTestgeneratorDSL.g:12732:3: rule__BooleanCompare__ValueAssignment_2
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            rule__BooleanCompare__ValueAssignment_2();
 
             state._fsp--;
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
+
+            }
+
+             after(grammarAccess.getBooleanCompareAccess().getValueAssignment_2()); 
 
             }
 
@@ -52223,29 +38542,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_0"
+    // $ANTLR end "rule__BooleanCompare__Group__2__Impl"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
-    // InternalTestgeneratorDSL.g:17314:1: rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__Model__DeclarationsAssignment"
+    // InternalTestgeneratorDSL.g:12741:1: rule__Model__DeclarationsAssignment : ( ruleDeclaration ) ;
+    public final void rule__Model__DeclarationsAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17318:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17319:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12745:1: ( ( ruleDeclaration ) )
+            // InternalTestgeneratorDSL.g:12746:2: ( ruleDeclaration )
             {
-            // InternalTestgeneratorDSL.g:17319:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17320:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12746:2: ( ruleDeclaration )
+            // InternalTestgeneratorDSL.g:12747:3: ruleDeclaration
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
+             before(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            ruleDeclaration();
 
             state._fsp--;
 
-             after(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
+             after(grammarAccess.getModelAccess().getDeclarationsDeclarationParserRuleCall_0()); 
 
             }
 
@@ -52264,29 +38583,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
+    // $ANTLR end "rule__Model__DeclarationsAssignment"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0"
-    // InternalTestgeneratorDSL.g:17329:1: rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:12756:1: rule__BPMNDiagram__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__BPMNDiagram__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17333:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17334:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12760:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12761:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17334:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17335:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12761:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12762:3: RULE_ID
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -52305,29 +38620,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_0"
+    // $ANTLR end "rule__BPMNDiagram__NameAssignment_1"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1"
-    // InternalTestgeneratorDSL.g:17344:1: rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__TestpackageAssignment_4"
+    // InternalTestgeneratorDSL.g:12771:1: rule__BPMNDiagram__TestpackageAssignment_4 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__TestpackageAssignment_4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17348:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17349:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12775:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12776:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17349:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17350:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12776:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12777:3: RULE_STRING
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getTestpackageSTRINGTerminalRuleCall_4_0()); 
 
             }
 
@@ -52346,29 +38657,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__InputVariablesAssignment_5_4_1_1"
+    // $ANTLR end "rule__BPMNDiagram__TestpackageAssignment_4"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0"
-    // InternalTestgeneratorDSL.g:17359:1: rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__BpmnAssignment_7"
+    // InternalTestgeneratorDSL.g:12786:1: rule__BPMNDiagram__BpmnAssignment_7 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__BpmnAssignment_7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17363:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17364:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12790:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12791:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17364:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17365:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12791:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12792:3: RULE_STRING
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getBpmnSTRINGTerminalRuleCall_7_0()); 
 
             }
 
@@ -52387,29 +38694,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_0"
+    // $ANTLR end "rule__BPMNDiagram__BpmnAssignment_7"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
-    // InternalTestgeneratorDSL.g:17374:1: rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__KeyAssignment_10"
+    // InternalTestgeneratorDSL.g:12801:1: rule__BPMNDiagram__KeyAssignment_10 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__KeyAssignment_10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17378:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17379:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12805:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12806:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17379:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17380:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12806:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12807:3: RULE_STRING
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getKeySTRINGTerminalRuleCall_10_0()); 
 
             }
 
@@ -52428,25 +38731,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
+    // $ANTLR end "rule__BPMNDiagram__KeyAssignment_10"
 
 
-    // $ANTLR start "rule__ManualTaskFlowElement__LabelAssignment_7_3"
-    // InternalTestgeneratorDSL.g:17389:1: rule__ManualTaskFlowElement__LabelAssignment_7_3 : ( RULE_STRING ) ;
-    public final void rule__ManualTaskFlowElement__LabelAssignment_7_3() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__DmnAssignment_11_4_0"
+    // InternalTestgeneratorDSL.g:12816:1: rule__BPMNDiagram__DmnAssignment_11_4_0 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__DmnAssignment_11_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17393:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17394:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12820:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12821:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17394:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17395:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12821:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12822:3: RULE_STRING
             {
-             before(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
+             after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_0_0()); 
 
             }
 
@@ -52465,25 +38768,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ManualTaskFlowElement__LabelAssignment_7_3"
+    // $ANTLR end "rule__BPMNDiagram__DmnAssignment_11_4_0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17404:1: rule__ScriptTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__ScriptTaskFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__DmnAssignment_11_4_1_1"
+    // InternalTestgeneratorDSL.g:12831:1: rule__BPMNDiagram__DmnAssignment_11_4_1_1 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__DmnAssignment_11_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17408:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17409:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12835:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12836:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17409:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17410:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12836:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12837:3: RULE_STRING
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getDmnSTRINGTerminalRuleCall_11_4_1_1_0()); 
 
             }
 
@@ -52502,29 +38805,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__BPMNDiagram__DmnAssignment_11_4_1_1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0"
-    // InternalTestgeneratorDSL.g:17419:1: rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__EmbeddedAssignment_12_4_0"
+    // InternalTestgeneratorDSL.g:12846:1: rule__BPMNDiagram__EmbeddedAssignment_12_4_0 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__EmbeddedAssignment_12_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17423:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17424:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12850:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12851:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17424:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17425:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12851:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12852:3: RULE_STRING
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
-
-            state._fsp--;
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_0_0()); 
 
             }
 
@@ -52543,29 +38842,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_0"
+    // $ANTLR end "rule__BPMNDiagram__EmbeddedAssignment_12_4_0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
-    // InternalTestgeneratorDSL.g:17434:1: rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1"
+    // InternalTestgeneratorDSL.g:12861:1: rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1 : ( RULE_STRING ) ;
+    public final void rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17438:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17439:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:12865:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:12866:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17439:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17440:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:12866:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12867:3: RULE_STRING
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
-
-            state._fsp--;
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0()); 
+             before(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBPMNDiagramAccess().getEmbeddedSTRINGTerminalRuleCall_12_4_1_1_0()); 
 
             }
 
@@ -52584,29 +38879,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__HardcodedInputsAssignment_4_5_1_1"
+    // $ANTLR end "rule__BPMNDiagram__EmbeddedAssignment_12_4_1_1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0"
-    // InternalTestgeneratorDSL.g:17449:1: rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0() throws RecognitionException {
+    // $ANTLR start "rule__BPMNReference__RefAssignment"
+    // InternalTestgeneratorDSL.g:12876:1: rule__BPMNReference__RefAssignment : ( ( RULE_ID ) ) ;
+    public final void rule__BPMNReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17453:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17454:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12880:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:12881:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:17454:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17455:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12881:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12882:3: ( RULE_ID )
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
+             before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); 
+            // InternalTestgeneratorDSL.g:12883:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12884:4: RULE_ID
+            {
+             before(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramIDTerminalRuleCall_0_1()); 
 
-            state._fsp--;
+            }
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0()); 
+             after(grammarAccess.getBPMNReferenceAccess().getRefBPMNDiagramCrossReference_0()); 
 
             }
 
@@ -52625,29 +38924,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_0"
+    // $ANTLR end "rule__BPMNReference__RefAssignment"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1"
-    // InternalTestgeneratorDSL.g:17464:1: rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:12895:1: rule__StartFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__StartFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17468:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17469:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12899:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12900:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17469:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17470:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12900:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12901:3: RULE_ID
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0()); 
+             before(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getStartFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -52666,29 +38961,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__InputVariablesAssignment_5_4_1_1"
+    // $ANTLR end "rule__StartFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0"
-    // InternalTestgeneratorDSL.g:17479:1: rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__InputVariablesAssignment_4_4_0"
+    // InternalTestgeneratorDSL.g:12910:1: rule__StartFlowElement__InputVariablesAssignment_4_4_0 : ( ruleVariableReference ) ;
+    public final void rule__StartFlowElement__InputVariablesAssignment_4_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17483:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17484:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12914:1: ( ( ruleVariableReference ) )
+            // InternalTestgeneratorDSL.g:12915:2: ( ruleVariableReference )
             {
-            // InternalTestgeneratorDSL.g:17484:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17485:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12915:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12916:3: ruleVariableReference
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+             before(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); 
             pushFollow(FOLLOW_2);
             ruleVariableReference();
 
             state._fsp--;
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+             after(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); 
 
             }
 
@@ -52707,29 +39002,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_0"
+    // $ANTLR end "rule__StartFlowElement__InputVariablesAssignment_4_4_0"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
-    // InternalTestgeneratorDSL.g:17494:1: rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__StartFlowElement__InputVariablesAssignment_4_4_1_1"
+    // InternalTestgeneratorDSL.g:12925:1: rule__StartFlowElement__InputVariablesAssignment_4_4_1_1 : ( ruleVariableReference ) ;
+    public final void rule__StartFlowElement__InputVariablesAssignment_4_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17498:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17499:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12929:1: ( ( ruleVariableReference ) )
+            // InternalTestgeneratorDSL.g:12930:2: ( ruleVariableReference )
             {
-            // InternalTestgeneratorDSL.g:17499:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17500:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:12930:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12931:3: ruleVariableReference
             {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
+             before(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); 
             pushFollow(FOLLOW_2);
             ruleVariableReference();
 
             state._fsp--;
 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
+             after(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); 
 
             }
 
@@ -52748,62 +39043,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ScriptTaskFlowElement__OutputVariablesAssignment_6_4_1_1"
+    // $ANTLR end "rule__StartFlowElement__InputVariablesAssignment_4_4_1_1"
 
 
-    // $ANTLR start "rule__ScriptTaskFlowElement__LabelAssignment_7_3"
-    // InternalTestgeneratorDSL.g:17509:1: rule__ScriptTaskFlowElement__LabelAssignment_7_3 : ( RULE_STRING ) ;
-    public final void rule__ScriptTaskFlowElement__LabelAssignment_7_3() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:17513:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17514:2: ( RULE_STRING )
-            {
-            // InternalTestgeneratorDSL.g:17514:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17515:3: RULE_STRING
-            {
-             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__ScriptTaskFlowElement__LabelAssignment_7_3"
-
-
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17524:1: rule__DelegateServiceTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__DelegateServiceTaskFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__EndFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:12940:1: rule__EndFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__EndFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17528:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17529:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12944:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12945:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17529:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17530:3: RULE_ID
+            // InternalTestgeneratorDSL.g:12945:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12946:3: RULE_ID
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             before(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             after(grammarAccess.getEndFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -52822,25 +39080,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__EndFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__DelegateAssignment_7"
-    // InternalTestgeneratorDSL.g:17539:1: rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 : ( RULE_STRING ) ;
-    public final void rule__DelegateServiceTaskFlowElement__DelegateAssignment_7() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:12955:1: rule__UserTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__UserTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17543:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17544:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12959:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:12960:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17544:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17545:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12960:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:12961:3: RULE_ID
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -52859,62 +39117,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__DelegateAssignment_7"
+    // $ANTLR end "rule__UserTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3"
-    // InternalTestgeneratorDSL.g:17554:1: rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 : ( RULE_STRING ) ;
-    public final void rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0"
+    // InternalTestgeneratorDSL.g:12970:1: rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0 : ( ruleVariableReference ) ;
+    public final void rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17558:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17559:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:12974:1: ( ( ruleVariableReference ) )
+            // InternalTestgeneratorDSL.g:12975:2: ( ruleVariableReference )
             {
-            // InternalTestgeneratorDSL.g:17559:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17560:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:12975:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12976:3: ruleVariableReference
             {
-             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
-
-            }
-
-
-            }
-
-        }
-        catch (RecognitionException re) {
-            reportError(re);
-            recover(input,re);
-        }
-        finally {
-
-            	restoreStackSize(stackSize);
-
-        }
-        return ;
-    }
-    // $ANTLR end "rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3"
+             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); 
+            pushFollow(FOLLOW_2);
+            ruleVariableReference();
 
+            state._fsp--;
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17569:1: rule__ExternalServiceTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__ExternalServiceTaskFlowElement__NameAssignment_1() throws RecognitionException {
-
-        		int stackSize = keepStackSize();
-        	
-        try {
-            // InternalTestgeneratorDSL.g:17573:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17574:2: ( RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:17574:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17575:3: RULE_ID
-            {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0()); 
 
             }
 
@@ -52933,29 +39158,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_0"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7"
-    // InternalTestgeneratorDSL.g:17584:1: rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 : ( ruleExternalTopicReference ) ;
-    public final void rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1"
+    // InternalTestgeneratorDSL.g:12985:1: rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1 : ( ruleVariableReference ) ;
+    public final void rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17588:1: ( ( ruleExternalTopicReference ) )
-            // InternalTestgeneratorDSL.g:17589:2: ( ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:12989:1: ( ( ruleVariableReference ) )
+            // InternalTestgeneratorDSL.g:12990:2: ( ruleVariableReference )
             {
-            // InternalTestgeneratorDSL.g:17589:2: ( ruleExternalTopicReference )
-            // InternalTestgeneratorDSL.g:17590:3: ruleExternalTopicReference
+            // InternalTestgeneratorDSL.g:12990:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:12991:3: ruleVariableReference
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); 
             pushFollow(FOLLOW_2);
-            ruleExternalTopicReference();
+            ruleVariableReference();
 
             state._fsp--;
 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0()); 
 
             }
 
@@ -52974,29 +39199,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7"
+    // $ANTLR end "rule__UserTaskFlowElement__InputVariablesAssignment_4_4_1_1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0"
-    // InternalTestgeneratorDSL.g:17599:1: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0() throws RecognitionException {
+    // $ANTLR start "rule__UserTaskFlowElement__LabelAssignment_5_3"
+    // InternalTestgeneratorDSL.g:13000:1: rule__UserTaskFlowElement__LabelAssignment_5_3 : ( RULE_STRING ) ;
+    public final void rule__UserTaskFlowElement__LabelAssignment_5_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17603:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17604:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13004:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13005:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17604:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17605:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13005:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13006:3: RULE_STRING
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); 
+             before(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); 
 
             }
 
@@ -53015,29 +39236,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0"
+    // $ANTLR end "rule__UserTaskFlowElement__LabelAssignment_5_3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1"
-    // InternalTestgeneratorDSL.g:17614:1: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:13015:1: rule__ManualTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__ManualTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17618:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17619:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13019:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13020:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17619:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17620:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13020:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13021:3: RULE_ID
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -53056,29 +39273,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1"
+    // $ANTLR end "rule__ManualTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0"
-    // InternalTestgeneratorDSL.g:17629:1: rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0() throws RecognitionException {
+    // $ANTLR start "rule__ManualTaskFlowElement__LabelAssignment_4_3"
+    // InternalTestgeneratorDSL.g:13030:1: rule__ManualTaskFlowElement__LabelAssignment_4_3 : ( RULE_STRING ) ;
+    public final void rule__ManualTaskFlowElement__LabelAssignment_4_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17633:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17634:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13034:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13035:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17634:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17635:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13035:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13036:3: RULE_STRING
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_0_0()); 
+             before(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); 
 
             }
 
@@ -53097,29 +39310,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_0"
+    // $ANTLR end "rule__ManualTaskFlowElement__LabelAssignment_4_3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1"
-    // InternalTestgeneratorDSL.g:17644:1: rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:13045:1: rule__ScriptTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__ScriptTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17648:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17649:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13049:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13050:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17649:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17650:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13050:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13051:3: RULE_ID
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -53138,29 +39347,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__InputVariablesAssignment_9_4_1_1"
+    // $ANTLR end "rule__ScriptTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0"
-    // InternalTestgeneratorDSL.g:17659:1: rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0 : ( ruleVariableReference ) ;
-    public final void rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0() throws RecognitionException {
+    // $ANTLR start "rule__ScriptTaskFlowElement__LabelAssignment_4_3"
+    // InternalTestgeneratorDSL.g:13060:1: rule__ScriptTaskFlowElement__LabelAssignment_4_3 : ( RULE_STRING ) ;
+    public final void rule__ScriptTaskFlowElement__LabelAssignment_4_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17663:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17664:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13064:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13065:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17664:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17665:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13065:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13066:3: RULE_STRING
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0()); 
+             before(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0()); 
 
             }
 
@@ -53179,29 +39384,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_0"
+    // $ANTLR end "rule__ScriptTaskFlowElement__LabelAssignment_4_3"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1"
-    // InternalTestgeneratorDSL.g:17674:1: rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:13075:1: rule__DelegateServiceTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__DelegateServiceTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17678:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17679:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13079:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13080:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17679:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17680:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13080:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13081:3: RULE_ID
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -53220,25 +39421,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__OutputVariablesAssignment_10_4_1_1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3"
-    // InternalTestgeneratorDSL.g:17689:1: rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3 : ( RULE_STRING ) ;
-    public final void rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__DelegateAssignment_7"
+    // InternalTestgeneratorDSL.g:13090:1: rule__DelegateServiceTaskFlowElement__DelegateAssignment_7 : ( RULE_STRING ) ;
+    public final void rule__DelegateServiceTaskFlowElement__DelegateAssignment_7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17693:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17694:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13094:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13095:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17694:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17695:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13095:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13096:3: RULE_STRING
             {
-             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_11_3_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_11_3_0()); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0()); 
 
             }
 
@@ -53257,25 +39458,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__ExternalServiceTaskFlowElement__LabelAssignment_11_3"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__DelegateAssignment_7"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17704:1: rule__BusinessRuleTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
-    public final void rule__BusinessRuleTaskFlowElement__NameAssignment_1() throws RecognitionException {
+    // $ANTLR start "rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3"
+    // InternalTestgeneratorDSL.g:13105:1: rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3 : ( RULE_STRING ) ;
+    public final void rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17708:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17709:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13109:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13110:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17709:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17710:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13110:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13111:3: RULE_STRING
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
-            match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+             before(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
 
             }
 
@@ -53294,25 +39495,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__NameAssignment_1"
+    // $ANTLR end "rule__DelegateServiceTaskFlowElement__LabelAssignment_8_3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3"
-    // InternalTestgeneratorDSL.g:17719:1: rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 : ( RULE_STRING ) ;
-    public final void rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:13120:1: rule__ExternalServiceTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__ExternalServiceTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17723:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17724:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13124:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13125:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17724:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17725:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13125:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13126:3: RULE_ID
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); 
-            match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -53331,29 +39532,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0"
-    // InternalTestgeneratorDSL.g:17734:1: rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0 : ( ruleVariableDeclaration ) ;
-    public final void rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7"
+    // InternalTestgeneratorDSL.g:13135:1: rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7 : ( ruleExternalTopicReference ) ;
+    public final void rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17738:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17739:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13139:1: ( ( ruleExternalTopicReference ) )
+            // InternalTestgeneratorDSL.g:13140:2: ( ruleExternalTopicReference )
             {
-            // InternalTestgeneratorDSL.g:17739:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17740:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13140:2: ( ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:13141:3: ruleExternalTopicReference
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableDeclaration();
+            ruleExternalTopicReference();
 
             state._fsp--;
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0()); 
 
             }
 
@@ -53372,29 +39573,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__ExternalTopicAssignment_7"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1"
-    // InternalTestgeneratorDSL.g:17749:1: rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1 : ( ruleVariableDeclaration ) ;
-    public final void rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0"
+    // InternalTestgeneratorDSL.g:13150:1: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0 : ( ruleVariableDeclaration ) ;
+    public final void rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17753:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:17754:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13154:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:13155:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:17754:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:17755:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13155:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13156:3: ruleVariableDeclaration
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); 
             pushFollow(FOLLOW_2);
             ruleVariableDeclaration();
 
             state._fsp--;
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0()); 
 
             }
 
@@ -53413,29 +39614,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__HardcodedInputsAssignment_5_5_1_1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_0"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0"
-    // InternalTestgeneratorDSL.g:17764:1: rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0 : ( ruleVariableReference ) ;
-    public final void rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1"
+    // InternalTestgeneratorDSL.g:13165:1: rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1 : ( ruleVariableDeclaration ) ;
+    public final void rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17768:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17769:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13169:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:13170:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:17769:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17770:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13170:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13171:3: ruleVariableDeclaration
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); 
             pushFollow(FOLLOW_2);
-            ruleVariableReference();
+            ruleVariableDeclaration();
 
             state._fsp--;
 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_0_0()); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0()); 
 
             }
 
@@ -53454,29 +39655,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_0"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__HardcodedInputsAssignment_8_5_1_1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1"
-    // InternalTestgeneratorDSL.g:17779:1: rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3"
+    // InternalTestgeneratorDSL.g:13180:1: rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3 : ( RULE_STRING ) ;
+    public final void rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17783:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17784:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13184:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13185:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17784:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17785:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13185:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13186:3: RULE_STRING
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0()); 
+             before(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_9_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_9_3_0()); 
 
             }
 
@@ -53495,29 +39692,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__InputVariablesAssignment_6_4_1_1"
+    // $ANTLR end "rule__ExternalServiceTaskFlowElement__LabelAssignment_9_3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0"
-    // InternalTestgeneratorDSL.g:17794:1: rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0 : ( ruleVariableReference ) ;
-    public final void rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__NameAssignment_1"
+    // InternalTestgeneratorDSL.g:13195:1: rule__BusinessRuleTaskFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    public final void rule__BusinessRuleTaskFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17798:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17799:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13199:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13200:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17799:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17800:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13200:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13201:3: RULE_ID
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
+            match(input,RULE_ID,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
 
             }
 
@@ -53536,29 +39729,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_0"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__NameAssignment_1"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1"
-    // InternalTestgeneratorDSL.g:17809:1: rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1 : ( ruleVariableReference ) ;
-    public final void rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3"
+    // InternalTestgeneratorDSL.g:13210:1: rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3 : ( RULE_STRING ) ;
+    public final void rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17813:1: ( ( ruleVariableReference ) )
-            // InternalTestgeneratorDSL.g:17814:2: ( ruleVariableReference )
+            // InternalTestgeneratorDSL.g:13214:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13215:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17814:2: ( ruleVariableReference )
-            // InternalTestgeneratorDSL.g:17815:3: ruleVariableReference
+            // InternalTestgeneratorDSL.g:13215:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13216:3: RULE_STRING
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0()); 
-            pushFollow(FOLLOW_2);
-            ruleVariableReference();
-
-            state._fsp--;
-
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); 
+            match(input,RULE_STRING,FOLLOW_2); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0()); 
 
             }
 
@@ -53577,25 +39766,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__OutputVariablesAssignment_7_4_1_1"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__ResultVariableAssignment_4_3"
 
 
-    // $ANTLR start "rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3"
-    // InternalTestgeneratorDSL.g:17824:1: rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3 : ( RULE_STRING ) ;
-    public final void rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3() throws RecognitionException {
+    // $ANTLR start "rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3"
+    // InternalTestgeneratorDSL.g:13225:1: rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3 : ( RULE_STRING ) ;
+    public final void rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17828:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17829:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13229:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13230:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17829:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17830:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13230:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13231:3: RULE_STRING
             {
-             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
+             before(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
-             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0()); 
+             after(grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0()); 
 
             }
 
@@ -53614,21 +39803,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__BusinessRuleTaskFlowElement__LabelAssignment_8_3"
+    // $ANTLR end "rule__BusinessRuleTaskFlowElement__LabelAssignment_5_3"
 
 
     // $ANTLR start "rule__GatewayFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17839:1: rule__GatewayFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13240:1: rule__GatewayFlowElement__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__GatewayFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17843:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17844:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13244:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13245:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17844:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17845:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13245:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13246:3: RULE_ID
             {
              before(grammarAccess.getGatewayFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53655,17 +39844,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__SequenceFlowElement__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17854:1: rule__SequenceFlowElement__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13255:1: rule__SequenceFlowElement__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__SequenceFlowElement__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17858:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17859:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13259:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13260:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17859:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17860:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13260:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13261:3: RULE_ID
             {
              before(grammarAccess.getSequenceFlowElementAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53692,17 +39881,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__SequenceFlowElement__ExpressionAssignment_4_3"
-    // InternalTestgeneratorDSL.g:17869:1: rule__SequenceFlowElement__ExpressionAssignment_4_3 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13270:1: rule__SequenceFlowElement__ExpressionAssignment_4_3 : ( RULE_STRING ) ;
     public final void rule__SequenceFlowElement__ExpressionAssignment_4_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17873:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17874:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13274:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13275:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17874:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17875:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13275:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13276:3: RULE_STRING
             {
              before(grammarAccess.getSequenceFlowElementAccess().getExpressionSTRINGTerminalRuleCall_4_3_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -53728,30 +39917,71 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
     // $ANTLR end "rule__SequenceFlowElement__ExpressionAssignment_4_3"
 
 
-    // $ANTLR start "rule__FlowElementReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:17884:1: rule__FlowElementReference__RefAssignment : ( ( RULE_ID ) ) ;
-    public final void rule__FlowElementReference__RefAssignment() throws RecognitionException {
+    // $ANTLR start "rule__FlowElementReference__RefAssignment_0"
+    // InternalTestgeneratorDSL.g:13285:1: rule__FlowElementReference__RefAssignment_0 : ( ( RULE_ID ) ) ;
+    public final void rule__FlowElementReference__RefAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17888:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:17889:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13289:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13290:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:17889:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17890:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13290:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13291:3: ( RULE_ID )
             {
-             before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:17891:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17892:4: RULE_ID
+             before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0_0()); 
+            // InternalTestgeneratorDSL.g:13292:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13293:4: RULE_ID
             {
-             before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_1()); 
+             before(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
-             after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_1()); 
+             after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementIDTerminalRuleCall_0_0_1()); 
+
+            }
+
+             after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0_0()); 
 
             }
 
-             after(grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0()); 
+
+            }
+
+        }
+        catch (RecognitionException re) {
+            reportError(re);
+            recover(input,re);
+        }
+        finally {
+
+            	restoreStackSize(stackSize);
+
+        }
+        return ;
+    }
+    // $ANTLR end "rule__FlowElementReference__RefAssignment_0"
+
+
+    // $ANTLR start "rule__FlowElementReference__FlagAssignment_1_1"
+    // InternalTestgeneratorDSL.g:13304:1: rule__FlowElementReference__FlagAssignment_1_1 : ( ruleFlag ) ;
+    public final void rule__FlowElementReference__FlagAssignment_1_1() throws RecognitionException {
+
+        		int stackSize = keepStackSize();
+        	
+        try {
+            // InternalTestgeneratorDSL.g:13308:1: ( ( ruleFlag ) )
+            // InternalTestgeneratorDSL.g:13309:2: ( ruleFlag )
+            {
+            // InternalTestgeneratorDSL.g:13309:2: ( ruleFlag )
+            // InternalTestgeneratorDSL.g:13310:3: ruleFlag
+            {
+             before(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0()); 
+            pushFollow(FOLLOW_2);
+            ruleFlag();
+
+            state._fsp--;
+
+             after(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0()); 
 
             }
 
@@ -53770,25 +40000,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
         }
         return ;
     }
-    // $ANTLR end "rule__FlowElementReference__RefAssignment"
+    // $ANTLR end "rule__FlowElementReference__FlagAssignment_1_1"
 
 
     // $ANTLR start "rule__DelegateServiceTaskReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:17903:1: rule__DelegateServiceTaskReference__RefAssignment : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13319:1: rule__DelegateServiceTaskReference__RefAssignment : ( ( RULE_ID ) ) ;
     public final void rule__DelegateServiceTaskReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17907:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:17908:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13323:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13324:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:17908:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17909:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13324:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13325:3: ( RULE_ID )
             {
              before(grammarAccess.getDelegateServiceTaskReferenceAccess().getRefDelegateServiceTaskFlowElementCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:17910:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17911:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13326:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13327:4: RULE_ID
             {
              before(grammarAccess.getDelegateServiceTaskReferenceAccess().getRefDelegateServiceTaskFlowElementIDTerminalRuleCall_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53819,17 +40049,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalTopic__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17922:1: rule__ExternalTopic__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13338:1: rule__ExternalTopic__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__ExternalTopic__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17926:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17927:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13342:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13343:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17927:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17928:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13343:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13344:3: RULE_ID
             {
              before(grammarAccess.getExternalTopicAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53856,21 +40086,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalTopicReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:17937:1: rule__ExternalTopicReference__RefAssignment : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13353:1: rule__ExternalTopicReference__RefAssignment : ( ( RULE_ID ) ) ;
     public final void rule__ExternalTopicReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17941:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:17942:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13357:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13358:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:17942:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17943:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13358:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13359:3: ( RULE_ID )
             {
              before(grammarAccess.getExternalTopicReferenceAccess().getRefExternalTopicCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:17944:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17945:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13360:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13361:4: RULE_ID
             {
              before(grammarAccess.getExternalTopicReferenceAccess().getRefExternalTopicIDTerminalRuleCall_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53901,21 +40131,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__VariableReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:17956:1: rule__VariableReference__RefAssignment : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13372:1: rule__VariableReference__RefAssignment : ( ( RULE_ID ) ) ;
     public final void rule__VariableReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17960:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:17961:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13376:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13377:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:17961:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17962:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13377:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13378:3: ( RULE_ID )
             {
              before(grammarAccess.getVariableReferenceAccess().getRefVariableCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:17963:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17964:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13379:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13380:4: RULE_ID
             {
              before(grammarAccess.getVariableReferenceAccess().getRefVariableIDTerminalRuleCall_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53946,17 +40176,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariable__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:17975:1: rule__StringVariable__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13391:1: rule__StringVariable__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__StringVariable__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17979:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:17980:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13395:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13396:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:17980:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:17981:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13396:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13397:3: RULE_ID
             {
              before(grammarAccess.getStringVariableAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -53983,17 +40213,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariable__ProposalsAssignment_6_0"
-    // InternalTestgeneratorDSL.g:17990:1: rule__StringVariable__ProposalsAssignment_6_0 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13406:1: rule__StringVariable__ProposalsAssignment_6_0 : ( RULE_STRING ) ;
     public final void rule__StringVariable__ProposalsAssignment_6_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:17994:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:17995:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13410:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13411:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:17995:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:17996:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13411:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13412:3: RULE_STRING
             {
              before(grammarAccess.getStringVariableAccess().getProposalsSTRINGTerminalRuleCall_6_0_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -54020,17 +40250,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariable__ProposalsAssignment_6_1_1"
-    // InternalTestgeneratorDSL.g:18005:1: rule__StringVariable__ProposalsAssignment_6_1_1 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13421:1: rule__StringVariable__ProposalsAssignment_6_1_1 : ( RULE_STRING ) ;
     public final void rule__StringVariable__ProposalsAssignment_6_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18009:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18010:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13425:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13426:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18010:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18011:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13426:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13427:3: RULE_STRING
             {
              before(grammarAccess.getStringVariableAccess().getProposalsSTRINGTerminalRuleCall_6_1_1_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -54057,17 +40287,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariable__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18020:1: rule__IntVariable__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13436:1: rule__IntVariable__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__IntVariable__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18024:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18025:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13440:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13441:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18025:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18026:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13441:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13442:3: RULE_ID
             {
              before(grammarAccess.getIntVariableAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54094,17 +40324,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariable__ProposalsAssignment_6_0"
-    // InternalTestgeneratorDSL.g:18035:1: rule__IntVariable__ProposalsAssignment_6_0 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13451:1: rule__IntVariable__ProposalsAssignment_6_0 : ( RULE_INT ) ;
     public final void rule__IntVariable__ProposalsAssignment_6_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18039:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18040:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13455:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13456:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18040:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18041:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13456:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13457:3: RULE_INT
             {
              before(grammarAccess.getIntVariableAccess().getProposalsINTTerminalRuleCall_6_0_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54131,17 +40361,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariable__ProposalsAssignment_6_1_1"
-    // InternalTestgeneratorDSL.g:18050:1: rule__IntVariable__ProposalsAssignment_6_1_1 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13466:1: rule__IntVariable__ProposalsAssignment_6_1_1 : ( RULE_INT ) ;
     public final void rule__IntVariable__ProposalsAssignment_6_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18054:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18055:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13470:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13471:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18055:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18056:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13471:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13472:3: RULE_INT
             {
              before(grammarAccess.getIntVariableAccess().getProposalsINTTerminalRuleCall_6_1_1_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54168,17 +40398,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariable__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18065:1: rule__BooleanVariable__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13481:1: rule__BooleanVariable__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__BooleanVariable__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18069:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18070:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13485:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13486:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18070:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18071:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13486:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13487:3: RULE_ID
             {
              before(grammarAccess.getBooleanVariableAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54205,17 +40435,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariable__ProposalsAssignment_6_0"
-    // InternalTestgeneratorDSL.g:18080:1: rule__BooleanVariable__ProposalsAssignment_6_0 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:13496:1: rule__BooleanVariable__ProposalsAssignment_6_0 : ( ruleBoolean ) ;
     public final void rule__BooleanVariable__ProposalsAssignment_6_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18084:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:18085:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:13500:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:13501:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:18085:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:18086:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:13501:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:13502:3: ruleBoolean
             {
              before(grammarAccess.getBooleanVariableAccess().getProposalsBooleanEnumRuleCall_6_0_0()); 
             pushFollow(FOLLOW_2);
@@ -54246,17 +40476,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariable__ProposalsAssignment_6_1_1"
-    // InternalTestgeneratorDSL.g:18095:1: rule__BooleanVariable__ProposalsAssignment_6_1_1 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:13511:1: rule__BooleanVariable__ProposalsAssignment_6_1_1 : ( ruleBoolean ) ;
     public final void rule__BooleanVariable__ProposalsAssignment_6_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18099:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:18100:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:13515:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:13516:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:18100:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:18101:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:13516:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:13517:3: ruleBoolean
             {
              before(grammarAccess.getBooleanVariableAccess().getProposalsBooleanEnumRuleCall_6_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -54287,17 +40517,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18110:1: rule__Loop__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13526:1: rule__Loop__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__Loop__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18114:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18115:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13530:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13531:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18115:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18116:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13531:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13532:3: RULE_ID
             {
              before(grammarAccess.getLoopAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54324,17 +40554,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__StartAssignment_4"
-    // InternalTestgeneratorDSL.g:18125:1: rule__Loop__StartAssignment_4 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13541:1: rule__Loop__StartAssignment_4 : ( RULE_STRING ) ;
     public final void rule__Loop__StartAssignment_4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18129:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18130:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13545:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13546:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18130:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18131:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13546:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13547:3: RULE_STRING
             {
              before(grammarAccess.getLoopAccess().getStartSTRINGTerminalRuleCall_4_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -54361,17 +40591,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__FollowerAssignment_7"
-    // InternalTestgeneratorDSL.g:18140:1: rule__Loop__FollowerAssignment_7 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13556:1: rule__Loop__FollowerAssignment_7 : ( RULE_STRING ) ;
     public final void rule__Loop__FollowerAssignment_7() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18144:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18145:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13560:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13561:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18145:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18146:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13561:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13562:3: RULE_STRING
             {
              before(grammarAccess.getLoopAccess().getFollowerSTRINGTerminalRuleCall_7_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -54398,17 +40628,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__EndAssignment_10"
-    // InternalTestgeneratorDSL.g:18155:1: rule__Loop__EndAssignment_10 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13571:1: rule__Loop__EndAssignment_10 : ( RULE_STRING ) ;
     public final void rule__Loop__EndAssignment_10() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18159:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18160:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13575:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13576:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18160:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18161:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13576:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13577:3: RULE_STRING
             {
              before(grammarAccess.getLoopAccess().getEndSTRINGTerminalRuleCall_10_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -54435,17 +40665,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__ComplexityAssignment_13"
-    // InternalTestgeneratorDSL.g:18170:1: rule__Loop__ComplexityAssignment_13 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13586:1: rule__Loop__ComplexityAssignment_13 : ( RULE_INT ) ;
     public final void rule__Loop__ComplexityAssignment_13() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18174:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18175:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13590:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13591:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18175:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18176:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13591:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13592:3: RULE_INT
             {
              before(grammarAccess.getLoopAccess().getComplexityINTTerminalRuleCall_13_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54472,17 +40702,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__FrequenciesAssignment_17_0"
-    // InternalTestgeneratorDSL.g:18185:1: rule__Loop__FrequenciesAssignment_17_0 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13601:1: rule__Loop__FrequenciesAssignment_17_0 : ( RULE_INT ) ;
     public final void rule__Loop__FrequenciesAssignment_17_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18189:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18190:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13605:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13606:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18190:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18191:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13606:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13607:3: RULE_INT
             {
              before(grammarAccess.getLoopAccess().getFrequenciesINTTerminalRuleCall_17_0_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54509,17 +40739,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Loop__FrequenciesAssignment_17_1_1"
-    // InternalTestgeneratorDSL.g:18200:1: rule__Loop__FrequenciesAssignment_17_1_1 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13616:1: rule__Loop__FrequenciesAssignment_17_1_1 : ( RULE_INT ) ;
     public final void rule__Loop__FrequenciesAssignment_17_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18204:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18205:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13620:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13621:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18205:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18206:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13621:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13622:3: RULE_INT
             {
              before(grammarAccess.getLoopAccess().getFrequenciesINTTerminalRuleCall_17_1_1_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54546,17 +40776,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18215:1: rule__Flow__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13631:1: rule__Flow__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__Flow__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18219:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18220:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13635:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13636:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18220:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18221:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13636:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13637:3: RULE_ID
             {
              before(grammarAccess.getFlowAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54583,17 +40813,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__BpmnReferenceAssignment_3"
-    // InternalTestgeneratorDSL.g:18230:1: rule__Flow__BpmnReferenceAssignment_3 : ( ruleBPMNReference ) ;
+    // InternalTestgeneratorDSL.g:13646:1: rule__Flow__BpmnReferenceAssignment_3 : ( ruleBPMNReference ) ;
     public final void rule__Flow__BpmnReferenceAssignment_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18234:1: ( ( ruleBPMNReference ) )
-            // InternalTestgeneratorDSL.g:18235:2: ( ruleBPMNReference )
+            // InternalTestgeneratorDSL.g:13650:1: ( ( ruleBPMNReference ) )
+            // InternalTestgeneratorDSL.g:13651:2: ( ruleBPMNReference )
             {
-            // InternalTestgeneratorDSL.g:18235:2: ( ruleBPMNReference )
-            // InternalTestgeneratorDSL.g:18236:3: ruleBPMNReference
+            // InternalTestgeneratorDSL.g:13651:2: ( ruleBPMNReference )
+            // InternalTestgeneratorDSL.g:13652:3: ruleBPMNReference
             {
              before(grammarAccess.getFlowAccess().getBpmnReferenceBPMNReferenceParserRuleCall_3_0()); 
             pushFollow(FOLLOW_2);
@@ -54624,17 +40854,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__FlagAssignment_4_3"
-    // InternalTestgeneratorDSL.g:18245:1: rule__Flow__FlagAssignment_4_3 : ( ruleFlag ) ;
+    // InternalTestgeneratorDSL.g:13661:1: rule__Flow__FlagAssignment_4_3 : ( ruleFlag ) ;
     public final void rule__Flow__FlagAssignment_4_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18249:1: ( ( ruleFlag ) )
-            // InternalTestgeneratorDSL.g:18250:2: ( ruleFlag )
+            // InternalTestgeneratorDSL.g:13665:1: ( ( ruleFlag ) )
+            // InternalTestgeneratorDSL.g:13666:2: ( ruleFlag )
             {
-            // InternalTestgeneratorDSL.g:18250:2: ( ruleFlag )
-            // InternalTestgeneratorDSL.g:18251:3: ruleFlag
+            // InternalTestgeneratorDSL.g:13666:2: ( ruleFlag )
+            // InternalTestgeneratorDSL.g:13667:3: ruleFlag
             {
              before(grammarAccess.getFlowAccess().getFlagFlagEnumRuleCall_4_3_0()); 
             pushFollow(FOLLOW_2);
@@ -54665,17 +40895,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__InclElementsAssignment_9_0"
-    // InternalTestgeneratorDSL.g:18260:1: rule__Flow__InclElementsAssignment_9_0 : ( ruleFlowElementReference ) ;
+    // InternalTestgeneratorDSL.g:13676:1: rule__Flow__InclElementsAssignment_9_0 : ( ruleFlowElementReference ) ;
     public final void rule__Flow__InclElementsAssignment_9_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18264:1: ( ( ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:18265:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13680:1: ( ( ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:13681:2: ( ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:18265:2: ( ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:18266:3: ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:13681:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13682:3: ruleFlowElementReference
             {
              before(grammarAccess.getFlowAccess().getInclElementsFlowElementReferenceParserRuleCall_9_0_0()); 
             pushFollow(FOLLOW_2);
@@ -54706,17 +40936,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__InclElementsAssignment_9_1_1"
-    // InternalTestgeneratorDSL.g:18275:1: rule__Flow__InclElementsAssignment_9_1_1 : ( ruleFlowElementReference ) ;
+    // InternalTestgeneratorDSL.g:13691:1: rule__Flow__InclElementsAssignment_9_1_1 : ( ruleFlowElementReference ) ;
     public final void rule__Flow__InclElementsAssignment_9_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18279:1: ( ( ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:18280:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13695:1: ( ( ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:13696:2: ( ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:18280:2: ( ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:18281:3: ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:13696:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13697:3: ruleFlowElementReference
             {
              before(grammarAccess.getFlowAccess().getInclElementsFlowElementReferenceParserRuleCall_9_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -54747,17 +40977,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__ExclElementsAssignment_11_4_0"
-    // InternalTestgeneratorDSL.g:18290:1: rule__Flow__ExclElementsAssignment_11_4_0 : ( ruleFlowElementReference ) ;
+    // InternalTestgeneratorDSL.g:13706:1: rule__Flow__ExclElementsAssignment_11_4_0 : ( ruleFlowElementReference ) ;
     public final void rule__Flow__ExclElementsAssignment_11_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18294:1: ( ( ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:18295:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13710:1: ( ( ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:13711:2: ( ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:18295:2: ( ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:18296:3: ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:13711:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13712:3: ruleFlowElementReference
             {
              before(grammarAccess.getFlowAccess().getExclElementsFlowElementReferenceParserRuleCall_11_4_0_0()); 
             pushFollow(FOLLOW_2);
@@ -54788,17 +41018,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Flow__ExclElementsAssignment_11_4_1_1"
-    // InternalTestgeneratorDSL.g:18305:1: rule__Flow__ExclElementsAssignment_11_4_1_1 : ( ruleFlowElementReference ) ;
+    // InternalTestgeneratorDSL.g:13721:1: rule__Flow__ExclElementsAssignment_11_4_1_1 : ( ruleFlowElementReference ) ;
     public final void rule__Flow__ExclElementsAssignment_11_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18309:1: ( ( ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:18310:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13725:1: ( ( ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:13726:2: ( ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:18310:2: ( ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:18311:3: ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:13726:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13727:3: ruleFlowElementReference
             {
              before(grammarAccess.getFlowAccess().getExclElementsFlowElementReferenceParserRuleCall_11_4_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -54829,21 +41059,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__FlowReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:18320:1: rule__FlowReference__RefAssignment : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13736:1: rule__FlowReference__RefAssignment : ( ( RULE_ID ) ) ;
     public final void rule__FlowReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18324:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18325:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13740:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13741:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18325:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18326:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13741:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13742:3: ( RULE_ID )
             {
              before(grammarAccess.getFlowReferenceAccess().getRefFlowCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:18327:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18328:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13743:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13744:4: RULE_ID
             {
              before(grammarAccess.getFlowReferenceAccess().getRefFlowIDTerminalRuleCall_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54874,17 +41104,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18339:1: rule__Test__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:13755:1: rule__Test__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__Test__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18343:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18344:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13759:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13760:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18344:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18345:3: RULE_ID
+            // InternalTestgeneratorDSL.g:13760:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13761:3: RULE_ID
             {
              before(grammarAccess.getTestAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -54911,17 +41141,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__FlowReferenceAssignment_3"
-    // InternalTestgeneratorDSL.g:18354:1: rule__Test__FlowReferenceAssignment_3 : ( ruleFlowReference ) ;
+    // InternalTestgeneratorDSL.g:13770:1: rule__Test__FlowReferenceAssignment_3 : ( ruleFlowReference ) ;
     public final void rule__Test__FlowReferenceAssignment_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18358:1: ( ( ruleFlowReference ) )
-            // InternalTestgeneratorDSL.g:18359:2: ( ruleFlowReference )
+            // InternalTestgeneratorDSL.g:13774:1: ( ( ruleFlowReference ) )
+            // InternalTestgeneratorDSL.g:13775:2: ( ruleFlowReference )
             {
-            // InternalTestgeneratorDSL.g:18359:2: ( ruleFlowReference )
-            // InternalTestgeneratorDSL.g:18360:3: ruleFlowReference
+            // InternalTestgeneratorDSL.g:13775:2: ( ruleFlowReference )
+            // InternalTestgeneratorDSL.g:13776:3: ruleFlowReference
             {
              before(grammarAccess.getTestAccess().getFlowReferenceFlowReferenceParserRuleCall_3_0()); 
             pushFollow(FOLLOW_2);
@@ -54952,17 +41182,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__PriorityAssignment_4_2"
-    // InternalTestgeneratorDSL.g:18369:1: rule__Test__PriorityAssignment_4_2 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:13785:1: rule__Test__PriorityAssignment_4_2 : ( RULE_INT ) ;
     public final void rule__Test__PriorityAssignment_4_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18373:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18374:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13789:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:13790:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18374:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18375:3: RULE_INT
+            // InternalTestgeneratorDSL.g:13790:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:13791:3: RULE_INT
             {
              before(grammarAccess.getTestAccess().getPriorityINTTerminalRuleCall_4_2_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -54989,17 +41219,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__DeclarationsAssignment_5_0"
-    // InternalTestgeneratorDSL.g:18384:1: rule__Test__DeclarationsAssignment_5_0 : ( ruleVariableDeclarations ) ;
+    // InternalTestgeneratorDSL.g:13800:1: rule__Test__DeclarationsAssignment_5_0 : ( ruleVariableDeclarations ) ;
     public final void rule__Test__DeclarationsAssignment_5_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18388:1: ( ( ruleVariableDeclarations ) )
-            // InternalTestgeneratorDSL.g:18389:2: ( ruleVariableDeclarations )
+            // InternalTestgeneratorDSL.g:13804:1: ( ( ruleVariableDeclarations ) )
+            // InternalTestgeneratorDSL.g:13805:2: ( ruleVariableDeclarations )
             {
-            // InternalTestgeneratorDSL.g:18389:2: ( ruleVariableDeclarations )
-            // InternalTestgeneratorDSL.g:18390:3: ruleVariableDeclarations
+            // InternalTestgeneratorDSL.g:13805:2: ( ruleVariableDeclarations )
+            // InternalTestgeneratorDSL.g:13806:3: ruleVariableDeclarations
             {
              before(grammarAccess.getTestAccess().getDeclarationsVariableDeclarationsParserRuleCall_5_0_0()); 
             pushFollow(FOLLOW_2);
@@ -55030,17 +41260,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__DeclarationsAssignment_5_1_1"
-    // InternalTestgeneratorDSL.g:18399:1: rule__Test__DeclarationsAssignment_5_1_1 : ( ruleVariableDeclarations ) ;
+    // InternalTestgeneratorDSL.g:13815:1: rule__Test__DeclarationsAssignment_5_1_1 : ( ruleVariableDeclarations ) ;
     public final void rule__Test__DeclarationsAssignment_5_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18403:1: ( ( ruleVariableDeclarations ) )
-            // InternalTestgeneratorDSL.g:18404:2: ( ruleVariableDeclarations )
+            // InternalTestgeneratorDSL.g:13819:1: ( ( ruleVariableDeclarations ) )
+            // InternalTestgeneratorDSL.g:13820:2: ( ruleVariableDeclarations )
             {
-            // InternalTestgeneratorDSL.g:18404:2: ( ruleVariableDeclarations )
-            // InternalTestgeneratorDSL.g:18405:3: ruleVariableDeclarations
+            // InternalTestgeneratorDSL.g:13820:2: ( ruleVariableDeclarations )
+            // InternalTestgeneratorDSL.g:13821:3: ruleVariableDeclarations
             {
              before(grammarAccess.getTestAccess().getDeclarationsVariableDeclarationsParserRuleCall_5_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -55071,17 +41301,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__EndCheckAssignment_6"
-    // InternalTestgeneratorDSL.g:18414:1: rule__Test__EndCheckAssignment_6 : ( ruleEndChecks ) ;
+    // InternalTestgeneratorDSL.g:13830:1: rule__Test__EndCheckAssignment_6 : ( ruleEndChecks ) ;
     public final void rule__Test__EndCheckAssignment_6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18418:1: ( ( ruleEndChecks ) )
-            // InternalTestgeneratorDSL.g:18419:2: ( ruleEndChecks )
+            // InternalTestgeneratorDSL.g:13834:1: ( ( ruleEndChecks ) )
+            // InternalTestgeneratorDSL.g:13835:2: ( ruleEndChecks )
             {
-            // InternalTestgeneratorDSL.g:18419:2: ( ruleEndChecks )
-            // InternalTestgeneratorDSL.g:18420:3: ruleEndChecks
+            // InternalTestgeneratorDSL.g:13835:2: ( ruleEndChecks )
+            // InternalTestgeneratorDSL.g:13836:3: ruleEndChecks
             {
              before(grammarAccess.getTestAccess().getEndCheckEndChecksParserRuleCall_6_0()); 
             pushFollow(FOLLOW_2);
@@ -55112,17 +41342,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__MocksAssignment_7_4_0"
-    // InternalTestgeneratorDSL.g:18429:1: rule__Test__MocksAssignment_7_4_0 : ( ruleMockReference ) ;
+    // InternalTestgeneratorDSL.g:13845:1: rule__Test__MocksAssignment_7_4_0 : ( ruleMockReference ) ;
     public final void rule__Test__MocksAssignment_7_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18433:1: ( ( ruleMockReference ) )
-            // InternalTestgeneratorDSL.g:18434:2: ( ruleMockReference )
+            // InternalTestgeneratorDSL.g:13849:1: ( ( ruleMockReference ) )
+            // InternalTestgeneratorDSL.g:13850:2: ( ruleMockReference )
             {
-            // InternalTestgeneratorDSL.g:18434:2: ( ruleMockReference )
-            // InternalTestgeneratorDSL.g:18435:3: ruleMockReference
+            // InternalTestgeneratorDSL.g:13850:2: ( ruleMockReference )
+            // InternalTestgeneratorDSL.g:13851:3: ruleMockReference
             {
              before(grammarAccess.getTestAccess().getMocksMockReferenceParserRuleCall_7_4_0_0()); 
             pushFollow(FOLLOW_2);
@@ -55153,17 +41383,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__Test__MocksAssignment_7_4_1_1"
-    // InternalTestgeneratorDSL.g:18444:1: rule__Test__MocksAssignment_7_4_1_1 : ( ruleMockReference ) ;
+    // InternalTestgeneratorDSL.g:13860:1: rule__Test__MocksAssignment_7_4_1_1 : ( ruleMockReference ) ;
     public final void rule__Test__MocksAssignment_7_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18448:1: ( ( ruleMockReference ) )
-            // InternalTestgeneratorDSL.g:18449:2: ( ruleMockReference )
+            // InternalTestgeneratorDSL.g:13864:1: ( ( ruleMockReference ) )
+            // InternalTestgeneratorDSL.g:13865:2: ( ruleMockReference )
             {
-            // InternalTestgeneratorDSL.g:18449:2: ( ruleMockReference )
-            // InternalTestgeneratorDSL.g:18450:3: ruleMockReference
+            // InternalTestgeneratorDSL.g:13865:2: ( ruleMockReference )
+            // InternalTestgeneratorDSL.g:13866:3: ruleMockReference
             {
              before(grammarAccess.getTestAccess().getMocksMockReferenceParserRuleCall_7_4_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -55194,17 +41424,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__VariableDeclarations__TaskReferenceAssignment_3"
-    // InternalTestgeneratorDSL.g:18459:1: rule__VariableDeclarations__TaskReferenceAssignment_3 : ( ruleFlowElementReference ) ;
+    // InternalTestgeneratorDSL.g:13875:1: rule__VariableDeclarations__TaskReferenceAssignment_3 : ( ruleFlowElementReference ) ;
     public final void rule__VariableDeclarations__TaskReferenceAssignment_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18463:1: ( ( ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:18464:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13879:1: ( ( ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:13880:2: ( ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:18464:2: ( ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:18465:3: ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:13880:2: ( ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:13881:3: ruleFlowElementReference
             {
              before(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceFlowElementReferenceParserRuleCall_3_0()); 
             pushFollow(FOLLOW_2);
@@ -55235,17 +41465,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__VariableDeclarations__VariablesAssignment_6_0"
-    // InternalTestgeneratorDSL.g:18474:1: rule__VariableDeclarations__VariablesAssignment_6_0 : ( ruleVariableDeclaration ) ;
+    // InternalTestgeneratorDSL.g:13890:1: rule__VariableDeclarations__VariablesAssignment_6_0 : ( ruleVariableDeclaration ) ;
     public final void rule__VariableDeclarations__VariablesAssignment_6_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18478:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:18479:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13894:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:13895:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:18479:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:18480:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13895:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13896:3: ruleVariableDeclaration
             {
              before(grammarAccess.getVariableDeclarationsAccess().getVariablesVariableDeclarationParserRuleCall_6_0_0()); 
             pushFollow(FOLLOW_2);
@@ -55276,17 +41506,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__VariableDeclarations__VariablesAssignment_6_1_1"
-    // InternalTestgeneratorDSL.g:18489:1: rule__VariableDeclarations__VariablesAssignment_6_1_1 : ( ruleVariableDeclaration ) ;
+    // InternalTestgeneratorDSL.g:13905:1: rule__VariableDeclarations__VariablesAssignment_6_1_1 : ( ruleVariableDeclaration ) ;
     public final void rule__VariableDeclarations__VariablesAssignment_6_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18493:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:18494:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13909:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:13910:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:18494:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:18495:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:13910:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:13911:3: ruleVariableDeclaration
             {
              before(grammarAccess.getVariableDeclarationsAccess().getVariablesVariableDeclarationParserRuleCall_6_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -55317,17 +41547,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__EndChecks__EndChecksAssignment_4_0"
-    // InternalTestgeneratorDSL.g:18504:1: rule__EndChecks__EndChecksAssignment_4_0 : ( ruleEndCheck ) ;
+    // InternalTestgeneratorDSL.g:13920:1: rule__EndChecks__EndChecksAssignment_4_0 : ( ruleEndCheck ) ;
     public final void rule__EndChecks__EndChecksAssignment_4_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18508:1: ( ( ruleEndCheck ) )
-            // InternalTestgeneratorDSL.g:18509:2: ( ruleEndCheck )
+            // InternalTestgeneratorDSL.g:13924:1: ( ( ruleEndCheck ) )
+            // InternalTestgeneratorDSL.g:13925:2: ( ruleEndCheck )
             {
-            // InternalTestgeneratorDSL.g:18509:2: ( ruleEndCheck )
-            // InternalTestgeneratorDSL.g:18510:3: ruleEndCheck
+            // InternalTestgeneratorDSL.g:13925:2: ( ruleEndCheck )
+            // InternalTestgeneratorDSL.g:13926:3: ruleEndCheck
             {
              before(grammarAccess.getEndChecksAccess().getEndChecksEndCheckParserRuleCall_4_0_0()); 
             pushFollow(FOLLOW_2);
@@ -55358,17 +41588,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__EndChecks__EndChecksAssignment_4_1_1"
-    // InternalTestgeneratorDSL.g:18519:1: rule__EndChecks__EndChecksAssignment_4_1_1 : ( ruleEndCheck ) ;
+    // InternalTestgeneratorDSL.g:13935:1: rule__EndChecks__EndChecksAssignment_4_1_1 : ( ruleEndCheck ) ;
     public final void rule__EndChecks__EndChecksAssignment_4_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18523:1: ( ( ruleEndCheck ) )
-            // InternalTestgeneratorDSL.g:18524:2: ( ruleEndCheck )
+            // InternalTestgeneratorDSL.g:13939:1: ( ( ruleEndCheck ) )
+            // InternalTestgeneratorDSL.g:13940:2: ( ruleEndCheck )
             {
-            // InternalTestgeneratorDSL.g:18524:2: ( ruleEndCheck )
-            // InternalTestgeneratorDSL.g:18525:3: ruleEndCheck
+            // InternalTestgeneratorDSL.g:13940:2: ( ruleEndCheck )
+            // InternalTestgeneratorDSL.g:13941:3: ruleEndCheck
             {
              before(grammarAccess.getEndChecksAccess().getEndChecksEndCheckParserRuleCall_4_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -55399,21 +41629,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableDeclaration__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18534:1: rule__StringVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13950:1: rule__StringVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__StringVariableDeclaration__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18538:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18539:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13954:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13955:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18539:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18540:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13955:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13956:3: ( RULE_ID )
             {
              before(grammarAccess.getStringVariableDeclarationAccess().getKeyStringVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18541:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18542:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13957:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13958:4: RULE_ID
             {
              before(grammarAccess.getStringVariableDeclarationAccess().getKeyStringVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55444,17 +41674,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableDeclaration__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18553:1: rule__StringVariableDeclaration__ValueAssignment_2 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:13969:1: rule__StringVariableDeclaration__ValueAssignment_2 : ( RULE_STRING ) ;
     public final void rule__StringVariableDeclaration__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18557:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18558:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13973:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:13974:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18558:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18559:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:13974:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:13975:3: RULE_STRING
             {
              before(grammarAccess.getStringVariableDeclarationAccess().getValueSTRINGTerminalRuleCall_2_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -55481,21 +41711,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableDeclaration__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18568:1: rule__IntVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:13984:1: rule__IntVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__IntVariableDeclaration__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18572:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18573:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13988:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:13989:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18573:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18574:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13989:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:13990:3: ( RULE_ID )
             {
              before(grammarAccess.getIntVariableDeclarationAccess().getKeyIntVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18575:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18576:4: RULE_ID
+            // InternalTestgeneratorDSL.g:13991:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:13992:4: RULE_ID
             {
              before(grammarAccess.getIntVariableDeclarationAccess().getKeyIntVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55526,17 +41756,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableDeclaration__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18587:1: rule__IntVariableDeclaration__ValueAssignment_2 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:14003:1: rule__IntVariableDeclaration__ValueAssignment_2 : ( RULE_INT ) ;
     public final void rule__IntVariableDeclaration__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18591:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18592:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14007:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:14008:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18592:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18593:3: RULE_INT
+            // InternalTestgeneratorDSL.g:14008:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14009:3: RULE_INT
             {
              before(grammarAccess.getIntVariableDeclarationAccess().getValueINTTerminalRuleCall_2_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -55563,21 +41793,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableDeclaration__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18602:1: rule__BooleanVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14018:1: rule__BooleanVariableDeclaration__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__BooleanVariableDeclaration__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18606:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18607:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14022:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14023:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18607:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18608:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14023:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14024:3: ( RULE_ID )
             {
              before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyBooleanVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18609:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18610:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14025:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14026:4: RULE_ID
             {
              before(grammarAccess.getBooleanVariableDeclarationAccess().getKeyBooleanVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55608,17 +41838,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableDeclaration__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18621:1: rule__BooleanVariableDeclaration__ValueAssignment_2 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:14037:1: rule__BooleanVariableDeclaration__ValueAssignment_2 : ( ruleBoolean ) ;
     public final void rule__BooleanVariableDeclaration__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18625:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:18626:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14041:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:14042:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:18626:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:18627:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:14042:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14043:3: ruleBoolean
             {
              before(grammarAccess.getBooleanVariableDeclarationAccess().getValueBooleanEnumRuleCall_2_0()); 
             pushFollow(FOLLOW_2);
@@ -55649,21 +41879,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18636:1: rule__StringVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14052:1: rule__StringVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__StringVariableEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18640:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18641:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14056:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14057:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18641:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18642:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14057:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14058:3: ( RULE_ID )
             {
              before(grammarAccess.getStringVariableEqualsAccess().getKeyStringVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18643:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18644:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14059:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14060:4: RULE_ID
             {
              before(grammarAccess.getStringVariableEqualsAccess().getKeyStringVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55694,17 +41924,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18655:1: rule__StringVariableEquals__ValueAssignment_2 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14071:1: rule__StringVariableEquals__ValueAssignment_2 : ( RULE_STRING ) ;
     public final void rule__StringVariableEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18659:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18660:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14075:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14076:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18660:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18661:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14076:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14077:3: RULE_STRING
             {
              before(grammarAccess.getStringVariableEqualsAccess().getValueSTRINGTerminalRuleCall_2_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -55731,21 +41961,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18670:1: rule__IntVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14086:1: rule__IntVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__IntVariableEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18674:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18675:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14090:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14091:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18675:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18676:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14091:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14092:3: ( RULE_ID )
             {
              before(grammarAccess.getIntVariableEqualsAccess().getKeyIntVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18677:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18678:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14093:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14094:4: RULE_ID
             {
              before(grammarAccess.getIntVariableEqualsAccess().getKeyIntVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55776,17 +42006,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18689:1: rule__IntVariableEquals__ValueAssignment_2 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:14105:1: rule__IntVariableEquals__ValueAssignment_2 : ( RULE_INT ) ;
     public final void rule__IntVariableEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18693:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18694:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14109:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:14110:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18694:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18695:3: RULE_INT
+            // InternalTestgeneratorDSL.g:14110:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14111:3: RULE_INT
             {
              before(grammarAccess.getIntVariableEqualsAccess().getValueINTTerminalRuleCall_2_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -55813,21 +42043,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18704:1: rule__BooleanVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14120:1: rule__BooleanVariableEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__BooleanVariableEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18708:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18709:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14124:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14125:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18709:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18710:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14125:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14126:3: ( RULE_ID )
             {
              before(grammarAccess.getBooleanVariableEqualsAccess().getKeyBooleanVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18711:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18712:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14127:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14128:4: RULE_ID
             {
              before(grammarAccess.getBooleanVariableEqualsAccess().getKeyBooleanVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55858,17 +42088,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18723:1: rule__BooleanVariableEquals__ValueAssignment_2 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:14139:1: rule__BooleanVariableEquals__ValueAssignment_2 : ( ruleBoolean ) ;
     public final void rule__BooleanVariableEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18727:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:18728:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14143:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:14144:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:18728:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:18729:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:14144:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14145:3: ruleBoolean
             {
              before(grammarAccess.getBooleanVariableEqualsAccess().getValueBooleanEnumRuleCall_2_0()); 
             pushFollow(FOLLOW_2);
@@ -55899,21 +42129,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableNotEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18738:1: rule__StringVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14154:1: rule__StringVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__StringVariableNotEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18742:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18743:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14158:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14159:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18743:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18744:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14159:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14160:3: ( RULE_ID )
             {
              before(grammarAccess.getStringVariableNotEqualsAccess().getKeyStringVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18745:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18746:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14161:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14162:4: RULE_ID
             {
              before(grammarAccess.getStringVariableNotEqualsAccess().getKeyStringVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -55944,17 +42174,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringVariableNotEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18757:1: rule__StringVariableNotEquals__ValueAssignment_2 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14173:1: rule__StringVariableNotEquals__ValueAssignment_2 : ( RULE_STRING ) ;
     public final void rule__StringVariableNotEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18761:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18762:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14177:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14178:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18762:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18763:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14178:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14179:3: RULE_STRING
             {
              before(grammarAccess.getStringVariableNotEqualsAccess().getValueSTRINGTerminalRuleCall_2_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -55981,21 +42211,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableNotEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18772:1: rule__IntVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14188:1: rule__IntVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__IntVariableNotEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18776:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18777:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14192:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14193:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18777:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18778:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14193:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14194:3: ( RULE_ID )
             {
              before(grammarAccess.getIntVariableNotEqualsAccess().getKeyIntVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18779:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18780:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14195:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14196:4: RULE_ID
             {
              before(grammarAccess.getIntVariableNotEqualsAccess().getKeyIntVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56026,17 +42256,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntVariableNotEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18791:1: rule__IntVariableNotEquals__ValueAssignment_2 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:14207:1: rule__IntVariableNotEquals__ValueAssignment_2 : ( RULE_INT ) ;
     public final void rule__IntVariableNotEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18795:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:18796:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14211:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:14212:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:18796:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:18797:3: RULE_INT
+            // InternalTestgeneratorDSL.g:14212:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14213:3: RULE_INT
             {
              before(grammarAccess.getIntVariableNotEqualsAccess().getValueINTTerminalRuleCall_2_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -56063,21 +42293,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableNotEquals__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:18806:1: rule__BooleanVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14222:1: rule__BooleanVariableNotEquals__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__BooleanVariableNotEquals__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18810:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18811:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14226:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14227:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18811:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18812:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14227:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14228:3: ( RULE_ID )
             {
              before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyBooleanVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:18813:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18814:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14229:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14230:4: RULE_ID
             {
              before(grammarAccess.getBooleanVariableNotEqualsAccess().getKeyBooleanVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56108,17 +42338,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanVariableNotEquals__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:18825:1: rule__BooleanVariableNotEquals__ValueAssignment_2 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:14241:1: rule__BooleanVariableNotEquals__ValueAssignment_2 : ( ruleBoolean ) ;
     public final void rule__BooleanVariableNotEquals__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18829:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:18830:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14245:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:14246:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:18830:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:18831:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:14246:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14247:3: ruleBoolean
             {
              before(grammarAccess.getBooleanVariableNotEqualsAccess().getValueBooleanEnumRuleCall_2_0()); 
             pushFollow(FOLLOW_2);
@@ -56149,21 +42379,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__MockReference__RefAssignment"
-    // InternalTestgeneratorDSL.g:18840:1: rule__MockReference__RefAssignment : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14256:1: rule__MockReference__RefAssignment : ( ( RULE_ID ) ) ;
     public final void rule__MockReference__RefAssignment() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18844:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:18845:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14260:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14261:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:18845:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18846:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14261:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14262:3: ( RULE_ID )
             {
              before(grammarAccess.getMockReferenceAccess().getRefMockCrossReference_0()); 
-            // InternalTestgeneratorDSL.g:18847:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18848:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14263:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14264:4: RULE_ID
             {
              before(grammarAccess.getMockReferenceAccess().getRefMockIDTerminalRuleCall_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56194,17 +42424,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalServiceMock__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18859:1: rule__ExternalServiceMock__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:14275:1: rule__ExternalServiceMock__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__ExternalServiceMock__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18863:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18864:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14279:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14280:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18864:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18865:3: RULE_ID
+            // InternalTestgeneratorDSL.g:14280:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14281:3: RULE_ID
             {
              before(grammarAccess.getExternalServiceMockAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56231,17 +42461,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalServiceMock__ExternalTopicAssignment_4"
-    // InternalTestgeneratorDSL.g:18874:1: rule__ExternalServiceMock__ExternalTopicAssignment_4 : ( ruleExternalTopicReference ) ;
+    // InternalTestgeneratorDSL.g:14290:1: rule__ExternalServiceMock__ExternalTopicAssignment_4 : ( ruleExternalTopicReference ) ;
     public final void rule__ExternalServiceMock__ExternalTopicAssignment_4() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18878:1: ( ( ruleExternalTopicReference ) )
-            // InternalTestgeneratorDSL.g:18879:2: ( ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:14294:1: ( ( ruleExternalTopicReference ) )
+            // InternalTestgeneratorDSL.g:14295:2: ( ruleExternalTopicReference )
             {
-            // InternalTestgeneratorDSL.g:18879:2: ( ruleExternalTopicReference )
-            // InternalTestgeneratorDSL.g:18880:3: ruleExternalTopicReference
+            // InternalTestgeneratorDSL.g:14295:2: ( ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:14296:3: ruleExternalTopicReference
             {
              before(grammarAccess.getExternalServiceMockAccess().getExternalTopicExternalTopicReferenceParserRuleCall_4_0()); 
             pushFollow(FOLLOW_2);
@@ -56272,17 +42502,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalServiceMock__MockingRulesAssignment_5_0"
-    // InternalTestgeneratorDSL.g:18889:1: rule__ExternalServiceMock__MockingRulesAssignment_5_0 : ( ruleMockingRule ) ;
+    // InternalTestgeneratorDSL.g:14305:1: rule__ExternalServiceMock__MockingRulesAssignment_5_0 : ( ruleMockingRule ) ;
     public final void rule__ExternalServiceMock__MockingRulesAssignment_5_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18893:1: ( ( ruleMockingRule ) )
-            // InternalTestgeneratorDSL.g:18894:2: ( ruleMockingRule )
+            // InternalTestgeneratorDSL.g:14309:1: ( ( ruleMockingRule ) )
+            // InternalTestgeneratorDSL.g:14310:2: ( ruleMockingRule )
             {
-            // InternalTestgeneratorDSL.g:18894:2: ( ruleMockingRule )
-            // InternalTestgeneratorDSL.g:18895:3: ruleMockingRule
+            // InternalTestgeneratorDSL.g:14310:2: ( ruleMockingRule )
+            // InternalTestgeneratorDSL.g:14311:3: ruleMockingRule
             {
              before(grammarAccess.getExternalServiceMockAccess().getMockingRulesMockingRuleParserRuleCall_5_0_0()); 
             pushFollow(FOLLOW_2);
@@ -56313,17 +42543,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ExternalServiceMock__MockingRulesAssignment_5_1_1"
-    // InternalTestgeneratorDSL.g:18904:1: rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 : ( ruleMockingRule ) ;
+    // InternalTestgeneratorDSL.g:14320:1: rule__ExternalServiceMock__MockingRulesAssignment_5_1_1 : ( ruleMockingRule ) ;
     public final void rule__ExternalServiceMock__MockingRulesAssignment_5_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18908:1: ( ( ruleMockingRule ) )
-            // InternalTestgeneratorDSL.g:18909:2: ( ruleMockingRule )
+            // InternalTestgeneratorDSL.g:14324:1: ( ( ruleMockingRule ) )
+            // InternalTestgeneratorDSL.g:14325:2: ( ruleMockingRule )
             {
-            // InternalTestgeneratorDSL.g:18909:2: ( ruleMockingRule )
-            // InternalTestgeneratorDSL.g:18910:3: ruleMockingRule
+            // InternalTestgeneratorDSL.g:14325:2: ( ruleMockingRule )
+            // InternalTestgeneratorDSL.g:14326:3: ruleMockingRule
             {
              before(grammarAccess.getExternalServiceMockAccess().getMockingRulesMockingRuleParserRuleCall_5_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56354,17 +42584,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__DelegateMock__NameAssignment_1"
-    // InternalTestgeneratorDSL.g:18919:1: rule__DelegateMock__NameAssignment_1 : ( RULE_ID ) ;
+    // InternalTestgeneratorDSL.g:14335:1: rule__DelegateMock__NameAssignment_1 : ( RULE_ID ) ;
     public final void rule__DelegateMock__NameAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18923:1: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:18924:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14339:1: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14340:2: ( RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:18924:2: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:18925:3: RULE_ID
+            // InternalTestgeneratorDSL.g:14340:2: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14341:3: RULE_ID
             {
              before(grammarAccess.getDelegateMockAccess().getNameIDTerminalRuleCall_1_0()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56391,17 +42621,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__DelegateMock__ServiceTaskReferenceAssignment_3"
-    // InternalTestgeneratorDSL.g:18934:1: rule__DelegateMock__ServiceTaskReferenceAssignment_3 : ( ruleDelegateServiceTaskReference ) ;
+    // InternalTestgeneratorDSL.g:14350:1: rule__DelegateMock__ServiceTaskReferenceAssignment_3 : ( ruleDelegateServiceTaskReference ) ;
     public final void rule__DelegateMock__ServiceTaskReferenceAssignment_3() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18938:1: ( ( ruleDelegateServiceTaskReference ) )
-            // InternalTestgeneratorDSL.g:18939:2: ( ruleDelegateServiceTaskReference )
+            // InternalTestgeneratorDSL.g:14354:1: ( ( ruleDelegateServiceTaskReference ) )
+            // InternalTestgeneratorDSL.g:14355:2: ( ruleDelegateServiceTaskReference )
             {
-            // InternalTestgeneratorDSL.g:18939:2: ( ruleDelegateServiceTaskReference )
-            // InternalTestgeneratorDSL.g:18940:3: ruleDelegateServiceTaskReference
+            // InternalTestgeneratorDSL.g:14355:2: ( ruleDelegateServiceTaskReference )
+            // InternalTestgeneratorDSL.g:14356:3: ruleDelegateServiceTaskReference
             {
              before(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceDelegateServiceTaskReferenceParserRuleCall_3_0()); 
             pushFollow(FOLLOW_2);
@@ -56432,17 +42662,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__DelegateMock__DelegateClassAssignment_6"
-    // InternalTestgeneratorDSL.g:18949:1: rule__DelegateMock__DelegateClassAssignment_6 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14365:1: rule__DelegateMock__DelegateClassAssignment_6 : ( RULE_STRING ) ;
     public final void rule__DelegateMock__DelegateClassAssignment_6() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18953:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:18954:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14369:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14370:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:18954:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:18955:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14370:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14371:3: RULE_STRING
             {
              before(grammarAccess.getDelegateMockAccess().getDelegateClassSTRINGTerminalRuleCall_6_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -56469,17 +42699,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__DelegateMock__ManualMocksAssignment_7_0"
-    // InternalTestgeneratorDSL.g:18964:1: rule__DelegateMock__ManualMocksAssignment_7_0 : ( ruleManualMock ) ;
+    // InternalTestgeneratorDSL.g:14380:1: rule__DelegateMock__ManualMocksAssignment_7_0 : ( ruleManualMock ) ;
     public final void rule__DelegateMock__ManualMocksAssignment_7_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18968:1: ( ( ruleManualMock ) )
-            // InternalTestgeneratorDSL.g:18969:2: ( ruleManualMock )
+            // InternalTestgeneratorDSL.g:14384:1: ( ( ruleManualMock ) )
+            // InternalTestgeneratorDSL.g:14385:2: ( ruleManualMock )
             {
-            // InternalTestgeneratorDSL.g:18969:2: ( ruleManualMock )
-            // InternalTestgeneratorDSL.g:18970:3: ruleManualMock
+            // InternalTestgeneratorDSL.g:14385:2: ( ruleManualMock )
+            // InternalTestgeneratorDSL.g:14386:3: ruleManualMock
             {
              before(grammarAccess.getDelegateMockAccess().getManualMocksManualMockParserRuleCall_7_0_0()); 
             pushFollow(FOLLOW_2);
@@ -56510,17 +42740,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__DelegateMock__ManualMocksAssignment_7_1_1"
-    // InternalTestgeneratorDSL.g:18979:1: rule__DelegateMock__ManualMocksAssignment_7_1_1 : ( ruleManualMock ) ;
+    // InternalTestgeneratorDSL.g:14395:1: rule__DelegateMock__ManualMocksAssignment_7_1_1 : ( ruleManualMock ) ;
     public final void rule__DelegateMock__ManualMocksAssignment_7_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18983:1: ( ( ruleManualMock ) )
-            // InternalTestgeneratorDSL.g:18984:2: ( ruleManualMock )
+            // InternalTestgeneratorDSL.g:14399:1: ( ( ruleManualMock ) )
+            // InternalTestgeneratorDSL.g:14400:2: ( ruleManualMock )
             {
-            // InternalTestgeneratorDSL.g:18984:2: ( ruleManualMock )
-            // InternalTestgeneratorDSL.g:18985:3: ruleManualMock
+            // InternalTestgeneratorDSL.g:14400:2: ( ruleManualMock )
+            // InternalTestgeneratorDSL.g:14401:3: ruleManualMock
             {
              before(grammarAccess.getDelegateMockAccess().getManualMocksManualMockParserRuleCall_7_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56551,17 +42781,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__MockingRule__ComparisonsAssignment_5_0"
-    // InternalTestgeneratorDSL.g:18994:1: rule__MockingRule__ComparisonsAssignment_5_0 : ( ruleCompare ) ;
+    // InternalTestgeneratorDSL.g:14410:1: rule__MockingRule__ComparisonsAssignment_5_0 : ( ruleCompare ) ;
     public final void rule__MockingRule__ComparisonsAssignment_5_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:18998:1: ( ( ruleCompare ) )
-            // InternalTestgeneratorDSL.g:18999:2: ( ruleCompare )
+            // InternalTestgeneratorDSL.g:14414:1: ( ( ruleCompare ) )
+            // InternalTestgeneratorDSL.g:14415:2: ( ruleCompare )
             {
-            // InternalTestgeneratorDSL.g:18999:2: ( ruleCompare )
-            // InternalTestgeneratorDSL.g:19000:3: ruleCompare
+            // InternalTestgeneratorDSL.g:14415:2: ( ruleCompare )
+            // InternalTestgeneratorDSL.g:14416:3: ruleCompare
             {
              before(grammarAccess.getMockingRuleAccess().getComparisonsCompareParserRuleCall_5_0_0()); 
             pushFollow(FOLLOW_2);
@@ -56592,17 +42822,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__MockingRule__ComparisonsAssignment_5_1_1"
-    // InternalTestgeneratorDSL.g:19009:1: rule__MockingRule__ComparisonsAssignment_5_1_1 : ( ruleCompare ) ;
+    // InternalTestgeneratorDSL.g:14425:1: rule__MockingRule__ComparisonsAssignment_5_1_1 : ( ruleCompare ) ;
     public final void rule__MockingRule__ComparisonsAssignment_5_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19013:1: ( ( ruleCompare ) )
-            // InternalTestgeneratorDSL.g:19014:2: ( ruleCompare )
+            // InternalTestgeneratorDSL.g:14429:1: ( ( ruleCompare ) )
+            // InternalTestgeneratorDSL.g:14430:2: ( ruleCompare )
             {
-            // InternalTestgeneratorDSL.g:19014:2: ( ruleCompare )
-            // InternalTestgeneratorDSL.g:19015:3: ruleCompare
+            // InternalTestgeneratorDSL.g:14430:2: ( ruleCompare )
+            // InternalTestgeneratorDSL.g:14431:3: ruleCompare
             {
              before(grammarAccess.getMockingRuleAccess().getComparisonsCompareParserRuleCall_5_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56633,17 +42863,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__MockingRule__VariablesAssignment_9_0"
-    // InternalTestgeneratorDSL.g:19024:1: rule__MockingRule__VariablesAssignment_9_0 : ( ruleVariableDeclaration ) ;
+    // InternalTestgeneratorDSL.g:14440:1: rule__MockingRule__VariablesAssignment_9_0 : ( ruleVariableDeclaration ) ;
     public final void rule__MockingRule__VariablesAssignment_9_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19028:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:19029:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:14444:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:14445:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:19029:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:19030:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:14445:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:14446:3: ruleVariableDeclaration
             {
              before(grammarAccess.getMockingRuleAccess().getVariablesVariableDeclarationParserRuleCall_9_0_0()); 
             pushFollow(FOLLOW_2);
@@ -56674,17 +42904,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__MockingRule__VariablesAssignment_9_1_1"
-    // InternalTestgeneratorDSL.g:19039:1: rule__MockingRule__VariablesAssignment_9_1_1 : ( ruleVariableDeclaration ) ;
+    // InternalTestgeneratorDSL.g:14455:1: rule__MockingRule__VariablesAssignment_9_1_1 : ( ruleVariableDeclaration ) ;
     public final void rule__MockingRule__VariablesAssignment_9_1_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19043:1: ( ( ruleVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:19044:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:14459:1: ( ( ruleVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:14460:2: ( ruleVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:19044:2: ( ruleVariableDeclaration )
-            // InternalTestgeneratorDSL.g:19045:3: ruleVariableDeclaration
+            // InternalTestgeneratorDSL.g:14460:2: ( ruleVariableDeclaration )
+            // InternalTestgeneratorDSL.g:14461:3: ruleVariableDeclaration
             {
              before(grammarAccess.getMockingRuleAccess().getVariablesVariableDeclarationParserRuleCall_9_1_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56715,17 +42945,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ManualMock__ServiceNameAssignment_2"
-    // InternalTestgeneratorDSL.g:19054:1: rule__ManualMock__ServiceNameAssignment_2 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14470:1: rule__ManualMock__ServiceNameAssignment_2 : ( RULE_STRING ) ;
     public final void rule__ManualMock__ServiceNameAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19058:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:19059:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14474:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14475:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:19059:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:19060:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14475:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14476:3: RULE_STRING
             {
              before(grammarAccess.getManualMockAccess().getServiceNameSTRINGTerminalRuleCall_2_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -56752,17 +42982,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__ManualMock__SetterAssignment_5"
-    // InternalTestgeneratorDSL.g:19069:1: rule__ManualMock__SetterAssignment_5 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14485:1: rule__ManualMock__SetterAssignment_5 : ( RULE_STRING ) ;
     public final void rule__ManualMock__SetterAssignment_5() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19073:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:19074:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14489:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14490:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:19074:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:19075:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14490:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14491:3: RULE_STRING
             {
              before(grammarAccess.getManualMockAccess().getSetterSTRINGTerminalRuleCall_5_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -56789,21 +43019,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringCompare__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:19084:1: rule__StringCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14500:1: rule__StringCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__StringCompare__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19088:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:19089:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14504:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14505:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:19089:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:19090:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14505:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14506:3: ( RULE_ID )
             {
              before(grammarAccess.getStringCompareAccess().getKeyStringVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:19091:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:19092:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14507:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14508:4: RULE_ID
             {
              before(grammarAccess.getStringCompareAccess().getKeyStringVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56834,17 +43064,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringCompare__CompareSymbolAssignment_1"
-    // InternalTestgeneratorDSL.g:19103:1: rule__StringCompare__CompareSymbolAssignment_1 : ( ruleStringCompareSymbol ) ;
+    // InternalTestgeneratorDSL.g:14519:1: rule__StringCompare__CompareSymbolAssignment_1 : ( ruleStringCompareSymbol ) ;
     public final void rule__StringCompare__CompareSymbolAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19107:1: ( ( ruleStringCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:19108:2: ( ruleStringCompareSymbol )
+            // InternalTestgeneratorDSL.g:14523:1: ( ( ruleStringCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:14524:2: ( ruleStringCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:19108:2: ( ruleStringCompareSymbol )
-            // InternalTestgeneratorDSL.g:19109:3: ruleStringCompareSymbol
+            // InternalTestgeneratorDSL.g:14524:2: ( ruleStringCompareSymbol )
+            // InternalTestgeneratorDSL.g:14525:3: ruleStringCompareSymbol
             {
              before(grammarAccess.getStringCompareAccess().getCompareSymbolStringCompareSymbolEnumRuleCall_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56875,17 +43105,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__StringCompare__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:19118:1: rule__StringCompare__ValueAssignment_2 : ( RULE_STRING ) ;
+    // InternalTestgeneratorDSL.g:14534:1: rule__StringCompare__ValueAssignment_2 : ( RULE_STRING ) ;
     public final void rule__StringCompare__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19122:1: ( ( RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:19123:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14538:1: ( ( RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:14539:2: ( RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:19123:2: ( RULE_STRING )
-            // InternalTestgeneratorDSL.g:19124:3: RULE_STRING
+            // InternalTestgeneratorDSL.g:14539:2: ( RULE_STRING )
+            // InternalTestgeneratorDSL.g:14540:3: RULE_STRING
             {
              before(grammarAccess.getStringCompareAccess().getValueSTRINGTerminalRuleCall_2_0()); 
             match(input,RULE_STRING,FOLLOW_2); 
@@ -56912,21 +43142,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntCompare__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:19133:1: rule__IntCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14549:1: rule__IntCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__IntCompare__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19137:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:19138:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14553:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14554:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:19138:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:19139:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14554:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14555:3: ( RULE_ID )
             {
              before(grammarAccess.getIntCompareAccess().getKeyIntVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:19140:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:19141:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14556:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14557:4: RULE_ID
             {
              before(grammarAccess.getIntCompareAccess().getKeyIntVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -56957,17 +43187,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntCompare__CompareSymbolAssignment_1"
-    // InternalTestgeneratorDSL.g:19152:1: rule__IntCompare__CompareSymbolAssignment_1 : ( ruleIntCompareSymbol ) ;
+    // InternalTestgeneratorDSL.g:14568:1: rule__IntCompare__CompareSymbolAssignment_1 : ( ruleIntCompareSymbol ) ;
     public final void rule__IntCompare__CompareSymbolAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19156:1: ( ( ruleIntCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:19157:2: ( ruleIntCompareSymbol )
+            // InternalTestgeneratorDSL.g:14572:1: ( ( ruleIntCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:14573:2: ( ruleIntCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:19157:2: ( ruleIntCompareSymbol )
-            // InternalTestgeneratorDSL.g:19158:3: ruleIntCompareSymbol
+            // InternalTestgeneratorDSL.g:14573:2: ( ruleIntCompareSymbol )
+            // InternalTestgeneratorDSL.g:14574:3: ruleIntCompareSymbol
             {
              before(grammarAccess.getIntCompareAccess().getCompareSymbolIntCompareSymbolEnumRuleCall_1_0()); 
             pushFollow(FOLLOW_2);
@@ -56998,17 +43228,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__IntCompare__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:19167:1: rule__IntCompare__ValueAssignment_2 : ( RULE_INT ) ;
+    // InternalTestgeneratorDSL.g:14583:1: rule__IntCompare__ValueAssignment_2 : ( RULE_INT ) ;
     public final void rule__IntCompare__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19171:1: ( ( RULE_INT ) )
-            // InternalTestgeneratorDSL.g:19172:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14587:1: ( ( RULE_INT ) )
+            // InternalTestgeneratorDSL.g:14588:2: ( RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:19172:2: ( RULE_INT )
-            // InternalTestgeneratorDSL.g:19173:3: RULE_INT
+            // InternalTestgeneratorDSL.g:14588:2: ( RULE_INT )
+            // InternalTestgeneratorDSL.g:14589:3: RULE_INT
             {
              before(grammarAccess.getIntCompareAccess().getValueINTTerminalRuleCall_2_0()); 
             match(input,RULE_INT,FOLLOW_2); 
@@ -57035,21 +43265,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanCompare__KeyAssignment_0"
-    // InternalTestgeneratorDSL.g:19182:1: rule__BooleanCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:14598:1: rule__BooleanCompare__KeyAssignment_0 : ( ( RULE_ID ) ) ;
     public final void rule__BooleanCompare__KeyAssignment_0() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19186:1: ( ( ( RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:19187:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14602:1: ( ( ( RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:14603:2: ( ( RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:19187:2: ( ( RULE_ID ) )
-            // InternalTestgeneratorDSL.g:19188:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14603:2: ( ( RULE_ID ) )
+            // InternalTestgeneratorDSL.g:14604:3: ( RULE_ID )
             {
              before(grammarAccess.getBooleanCompareAccess().getKeyBooleanVariableCrossReference_0_0()); 
-            // InternalTestgeneratorDSL.g:19189:3: ( RULE_ID )
-            // InternalTestgeneratorDSL.g:19190:4: RULE_ID
+            // InternalTestgeneratorDSL.g:14605:3: ( RULE_ID )
+            // InternalTestgeneratorDSL.g:14606:4: RULE_ID
             {
              before(grammarAccess.getBooleanCompareAccess().getKeyBooleanVariableIDTerminalRuleCall_0_0_1()); 
             match(input,RULE_ID,FOLLOW_2); 
@@ -57080,17 +43310,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanCompare__CompareSymbolAssignment_1"
-    // InternalTestgeneratorDSL.g:19201:1: rule__BooleanCompare__CompareSymbolAssignment_1 : ( ruleBooleanCompareSymbol ) ;
+    // InternalTestgeneratorDSL.g:14617:1: rule__BooleanCompare__CompareSymbolAssignment_1 : ( ruleBooleanCompareSymbol ) ;
     public final void rule__BooleanCompare__CompareSymbolAssignment_1() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19205:1: ( ( ruleBooleanCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:19206:2: ( ruleBooleanCompareSymbol )
+            // InternalTestgeneratorDSL.g:14621:1: ( ( ruleBooleanCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:14622:2: ( ruleBooleanCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:19206:2: ( ruleBooleanCompareSymbol )
-            // InternalTestgeneratorDSL.g:19207:3: ruleBooleanCompareSymbol
+            // InternalTestgeneratorDSL.g:14622:2: ( ruleBooleanCompareSymbol )
+            // InternalTestgeneratorDSL.g:14623:3: ruleBooleanCompareSymbol
             {
              before(grammarAccess.getBooleanCompareAccess().getCompareSymbolBooleanCompareSymbolEnumRuleCall_1_0()); 
             pushFollow(FOLLOW_2);
@@ -57121,17 +43351,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
 
     // $ANTLR start "rule__BooleanCompare__ValueAssignment_2"
-    // InternalTestgeneratorDSL.g:19216:1: rule__BooleanCompare__ValueAssignment_2 : ( ruleBoolean ) ;
+    // InternalTestgeneratorDSL.g:14632:1: rule__BooleanCompare__ValueAssignment_2 : ( ruleBoolean ) ;
     public final void rule__BooleanCompare__ValueAssignment_2() throws RecognitionException {
 
         		int stackSize = keepStackSize();
         	
         try {
-            // InternalTestgeneratorDSL.g:19220:1: ( ( ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:19221:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14636:1: ( ( ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:14637:2: ( ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:19221:2: ( ruleBoolean )
-            // InternalTestgeneratorDSL.g:19222:3: ruleBoolean
+            // InternalTestgeneratorDSL.g:14637:2: ( ruleBoolean )
+            // InternalTestgeneratorDSL.g:14638:3: ruleBoolean
             {
              before(grammarAccess.getBooleanCompareAccess().getValueBooleanEnumRuleCall_2_0()); 
             pushFollow(FOLLOW_2);
@@ -57165,15 +43395,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
     protected DFA3 dfa3 = new DFA3(this);
     static final String dfa_1s = "\15\uffff";
-    static final String dfa_2s = "\1\42\1\11\1\5\1\43\11\uffff";
-    static final String dfa_3s = "\1\42\1\11\1\5\1\65\11\uffff";
-    static final String dfa_4s = "\4\uffff\1\3\1\11\1\7\1\2\1\6\1\4\1\10\1\5\1\1";
+    static final String dfa_2s = "\1\43\1\11\1\5\1\44\11\uffff";
+    static final String dfa_3s = "\1\43\1\11\1\5\1\64\11\uffff";
+    static final String dfa_4s = "\4\uffff\1\3\1\7\1\5\1\10\1\2\1\1\1\6\1\4\1\11";
     static final String dfa_5s = "\15\uffff}>";
     static final String[] dfa_6s = {
             "\1\1",
             "\1\2",
             "\1\3",
-            "\1\14\3\uffff\1\7\1\4\4\uffff\1\11\1\13\1\10\2\uffff\1\6\1\uffff\1\12\1\5",
+            "\1\11\1\uffff\1\10\1\4\2\uffff\1\13\1\6\1\12\4\uffff\1\5\1\uffff\1\7\1\14",
             "",
             "",
             "",
@@ -57213,75 +43443,73 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalContentAssis
 
     public static final BitSet FOLLOW_1 = new BitSet(new long[]{0x0000000000000000L});
     public static final BitSet FOLLOW_2 = new BitSet(new long[]{0x0000000000000002L});
-    public static final BitSet FOLLOW_3 = new BitSet(new long[]{0x1D80000408000002L,0x0000000000028210L});
+    public static final BitSet FOLLOW_3 = new BitSet(new long[]{0x0EC0000810000002L,0x0000000000014108L});
     public static final BitSet FOLLOW_4 = new BitSet(new long[]{0x0000000000000200L});
-    public static final BitSet FOLLOW_5 = new BitSet(new long[]{0x0000000010000000L});
-    public static final BitSet FOLLOW_6 = new BitSet(new long[]{0x0000000020000000L});
+    public static final BitSet FOLLOW_5 = new BitSet(new long[]{0x0000000020000000L});
+    public static final BitSet FOLLOW_6 = new BitSet(new long[]{0x0000000040000000L});
     public static final BitSet FOLLOW_7 = new BitSet(new long[]{0x0000000000000400L});
-    public static final BitSet FOLLOW_8 = new BitSet(new long[]{0x0000000040000000L});
-    public static final BitSet FOLLOW_9 = new BitSet(new long[]{0x0000000080000000L});
-    public static final BitSet FOLLOW_10 = new BitSet(new long[]{0x0000000010000010L});
-    public static final BitSet FOLLOW_11 = new BitSet(new long[]{0x0000000100000000L});
+    public static final BitSet FOLLOW_8 = new BitSet(new long[]{0x0000000080000000L});
+    public static final BitSet FOLLOW_9 = new BitSet(new long[]{0x0000000100000000L});
+    public static final BitSet FOLLOW_10 = new BitSet(new long[]{0x0000000020000010L});
+    public static final BitSet FOLLOW_11 = new BitSet(new long[]{0x0000000200000000L});
     public static final BitSet FOLLOW_12 = new BitSet(new long[]{0x0000000000000020L});
     public static final BitSet FOLLOW_13 = new BitSet(new long[]{0x0000000000000040L});
     public static final BitSet FOLLOW_14 = new BitSet(new long[]{0x0000000000000480L});
     public static final BitSet FOLLOW_15 = new BitSet(new long[]{0x0000000000000100L});
     public static final BitSet FOLLOW_16 = new BitSet(new long[]{0x0000000000000102L});
-    public static final BitSet FOLLOW_17 = new BitSet(new long[]{0x0000000200000000L});
-    public static final BitSet FOLLOW_18 = new BitSet(new long[]{0x0000000800000000L});
-    public static final BitSet FOLLOW_19 = new BitSet(new long[]{0x0000001000000000L});
-    public static final BitSet FOLLOW_20 = new BitSet(new long[]{0x0000002000000000L});
-    public static final BitSet FOLLOW_21 = new BitSet(new long[]{0x0000000000000280L});
-    public static final BitSet FOLLOW_22 = new BitSet(new long[]{0x0000004000000000L});
+    public static final BitSet FOLLOW_17 = new BitSet(new long[]{0x0000000400000000L});
+    public static final BitSet FOLLOW_18 = new BitSet(new long[]{0x0000001000000000L});
+    public static final BitSet FOLLOW_19 = new BitSet(new long[]{0x0000002000000000L});
+    public static final BitSet FOLLOW_20 = new BitSet(new long[]{0x0000000000000280L});
+    public static final BitSet FOLLOW_21 = new BitSet(new long[]{0x0000004000000000L});
+    public static final BitSet FOLLOW_22 = new BitSet(new long[]{0x0000000000000010L});
     public static final BitSet FOLLOW_23 = new BitSet(new long[]{0x0000008000000000L});
-    public static final BitSet FOLLOW_24 = new BitSet(new long[]{0x0000000000000010L});
-    public static final BitSet FOLLOW_25 = new BitSet(new long[]{0x0000010000000000L});
-    public static final BitSet FOLLOW_26 = new BitSet(new long[]{0x0000080010000010L});
-    public static final BitSet FOLLOW_27 = new BitSet(new long[]{0x0000020000000000L});
-    public static final BitSet FOLLOW_28 = new BitSet(new long[]{0x0000040000000000L});
+    public static final BitSet FOLLOW_24 = new BitSet(new long[]{0x0000010020000010L});
+    public static final BitSet FOLLOW_25 = new BitSet(new long[]{0x0000020000000000L});
+    public static final BitSet FOLLOW_26 = new BitSet(new long[]{0x0000040000000000L});
+    public static final BitSet FOLLOW_27 = new BitSet(new long[]{0x0000010000000010L});
+    public static final BitSet FOLLOW_28 = new BitSet(new long[]{0x0000080000000000L});
     public static final BitSet FOLLOW_29 = new BitSet(new long[]{0x0000100000000000L});
     public static final BitSet FOLLOW_30 = new BitSet(new long[]{0x0000200000000000L});
     public static final BitSet FOLLOW_31 = new BitSet(new long[]{0x0000400000000000L});
     public static final BitSet FOLLOW_32 = new BitSet(new long[]{0x0000800000000000L});
     public static final BitSet FOLLOW_33 = new BitSet(new long[]{0x0001000000000000L});
-    public static final BitSet FOLLOW_34 = new BitSet(new long[]{0x0000080000000010L});
-    public static final BitSet FOLLOW_35 = new BitSet(new long[]{0x0002000000000000L});
-    public static final BitSet FOLLOW_36 = new BitSet(new long[]{0x0004000000000000L});
-    public static final BitSet FOLLOW_37 = new BitSet(new long[]{0x0008000000000000L});
-    public static final BitSet FOLLOW_38 = new BitSet(new long[]{0x0010000000000000L});
-    public static final BitSet FOLLOW_39 = new BitSet(new long[]{0x0020000000000000L});
-    public static final BitSet FOLLOW_40 = new BitSet(new long[]{0x0040000000000000L});
-    public static final BitSet FOLLOW_41 = new BitSet(new long[]{0x0200000000000000L});
-    public static final BitSet FOLLOW_42 = new BitSet(new long[]{0x0000000000000880L});
-    public static final BitSet FOLLOW_43 = new BitSet(new long[]{0x0000000000000800L});
-    public static final BitSet FOLLOW_44 = new BitSet(new long[]{0x0000000000030080L});
-    public static final BitSet FOLLOW_45 = new BitSet(new long[]{0x0000000000030000L});
+    public static final BitSet FOLLOW_34 = new BitSet(new long[]{0x0002000000000000L});
+    public static final BitSet FOLLOW_35 = new BitSet(new long[]{0x0004000000000000L});
+    public static final BitSet FOLLOW_36 = new BitSet(new long[]{0x0008000000000000L});
+    public static final BitSet FOLLOW_37 = new BitSet(new long[]{0x0010000000000000L});
+    public static final BitSet FOLLOW_38 = new BitSet(new long[]{0x0020000000000000L});
+    public static final BitSet FOLLOW_39 = new BitSet(new long[]{0x000000000F000000L});
+    public static final BitSet FOLLOW_40 = new BitSet(new long[]{0x0100000000000000L});
+    public static final BitSet FOLLOW_41 = new BitSet(new long[]{0x0000000000000880L});
+    public static final BitSet FOLLOW_42 = new BitSet(new long[]{0x0000000000000800L});
+    public static final BitSet FOLLOW_43 = new BitSet(new long[]{0x0000000000030080L});
+    public static final BitSet FOLLOW_44 = new BitSet(new long[]{0x0000000000030000L});
+    public static final BitSet FOLLOW_45 = new BitSet(new long[]{0x1000000000000000L});
     public static final BitSet FOLLOW_46 = new BitSet(new long[]{0x2000000000000000L});
     public static final BitSet FOLLOW_47 = new BitSet(new long[]{0x4000000000000000L});
     public static final BitSet FOLLOW_48 = new BitSet(new long[]{0x8000000000000000L});
     public static final BitSet FOLLOW_49 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000001L});
     public static final BitSet FOLLOW_50 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000002L});
     public static final BitSet FOLLOW_51 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000004L});
-    public static final BitSet FOLLOW_52 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000008L});
+    public static final BitSet FOLLOW_52 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000010L});
     public static final BitSet FOLLOW_53 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000020L});
-    public static final BitSet FOLLOW_54 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000040L});
-    public static final BitSet FOLLOW_55 = new BitSet(new long[]{0x0000000000000010L,0x0000000000000100L});
-    public static final BitSet FOLLOW_56 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000080L});
-    public static final BitSet FOLLOW_57 = new BitSet(new long[]{0x0000000007000000L});
-    public static final BitSet FOLLOW_58 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000400L});
-    public static final BitSet FOLLOW_59 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000800L});
-    public static final BitSet FOLLOW_60 = new BitSet(new long[]{0x0000000000000000L,0x0000000000001000L});
-    public static final BitSet FOLLOW_61 = new BitSet(new long[]{0x0000000000000000L,0x0000000000002000L});
-    public static final BitSet FOLLOW_62 = new BitSet(new long[]{0x0000000000000000L,0x0000000000004000L});
-    public static final BitSet FOLLOW_63 = new BitSet(new long[]{0x0000000000040000L});
-    public static final BitSet FOLLOW_64 = new BitSet(new long[]{0x0000000000080000L});
-    public static final BitSet FOLLOW_65 = new BitSet(new long[]{0x0000000000000000L,0x0000000000010000L});
-    public static final BitSet FOLLOW_66 = new BitSet(new long[]{0x0000000000000000L,0x0000000000040000L});
-    public static final BitSet FOLLOW_67 = new BitSet(new long[]{0x0000000000000000L,0x0000000000080000L});
-    public static final BitSet FOLLOW_68 = new BitSet(new long[]{0x0000000000000000L,0x0000000000100000L});
-    public static final BitSet FOLLOW_69 = new BitSet(new long[]{0x0000000000000000L,0x0000000000200000L});
-    public static final BitSet FOLLOW_70 = new BitSet(new long[]{0x0000000000000000L,0x0000000000400000L});
-    public static final BitSet FOLLOW_71 = new BitSet(new long[]{0x00000000000C0000L});
-    public static final BitSet FOLLOW_72 = new BitSet(new long[]{0x0000000000FC0000L});
+    public static final BitSet FOLLOW_54 = new BitSet(new long[]{0x0000000000000010L,0x0000000000000080L});
+    public static final BitSet FOLLOW_55 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000040L});
+    public static final BitSet FOLLOW_56 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000200L});
+    public static final BitSet FOLLOW_57 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000400L});
+    public static final BitSet FOLLOW_58 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000800L});
+    public static final BitSet FOLLOW_59 = new BitSet(new long[]{0x0000000000000000L,0x0000000000001000L});
+    public static final BitSet FOLLOW_60 = new BitSet(new long[]{0x0000000000000000L,0x0000000000002000L});
+    public static final BitSet FOLLOW_61 = new BitSet(new long[]{0x0000000000040000L});
+    public static final BitSet FOLLOW_62 = new BitSet(new long[]{0x0000000000080000L});
+    public static final BitSet FOLLOW_63 = new BitSet(new long[]{0x0000000000000000L,0x0000000000008000L});
+    public static final BitSet FOLLOW_64 = new BitSet(new long[]{0x0000000000000000L,0x0000000000020000L});
+    public static final BitSet FOLLOW_65 = new BitSet(new long[]{0x0000000000000000L,0x0000000000040000L});
+    public static final BitSet FOLLOW_66 = new BitSet(new long[]{0x0000000000000000L,0x0000000000080000L});
+    public static final BitSet FOLLOW_67 = new BitSet(new long[]{0x0000000000000000L,0x0000000000100000L});
+    public static final BitSet FOLLOW_68 = new BitSet(new long[]{0x0000000000000000L,0x0000000000200000L});
+    public static final BitSet FOLLOW_69 = new BitSet(new long[]{0x00000000000C0000L});
+    public static final BitSet FOLLOW_70 = new BitSet(new long[]{0x0000000000FC0000L});
 
 }
\ No newline at end of file
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeModule.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeModule.xtendbin
index 33e7618adc4034ae941b3018a0526f009f1b1447..9d078bfea1cc9b15ab530571735dd0e74c48de6e 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeModule.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeModule.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeSetup.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeSetup.xtendbin
index 1a66e561c4fd0d813bf5609d577456d09aee6e93..a50361afcbd3ad4356163229c3f66ac59f3d0bb7 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeSetup.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl.ide/xtend-gen/de/fhmuenster/masterthesis/ide/.TestgeneratorDSLIdeSetup.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.ecore b/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.ecore
index 04069b64496f4226ad3c468e84de2d634ce2f256..dd0dbddcf6ad71b7d52ccd3f7ca586dbec607cb4 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.ecore
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.ecore
@@ -257,8 +257,9 @@
     <eLiterals name="NOT_EQUALS" value="1" literal="!="/>
   </eClassifiers>
   <eClassifiers xsi:type="ecore:EEnum" name="Flag">
-    <eLiterals name="GREEN" literal="GREEN"/>
-    <eLiterals name="YELLOW" value="1" literal="YELLOW"/>
-    <eLiterals name="RED" value="2" literal="RED"/>
+    <eLiterals name="NONE" literal="NONE"/>
+    <eLiterals name="GREEN" value="1" literal="GREEN"/>
+    <eLiterals name="YELLOW" value="2" literal="YELLOW"/>
+    <eLiterals name="RED" value="3" literal="RED"/>
   </eClassifiers>
 </ecore:EPackage>
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.genmodel b/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.genmodel
index 7c92a870764a4b0cc035e79e28cd3177eabb1820..56e610a918a5252907f148deefa162ccdd4989ff 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.genmodel
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/model/generated/TestgeneratorDSL.genmodel
@@ -27,6 +27,7 @@
       <genEnumLiterals ecoreEnumLiteral="TestgeneratorDSL.ecore#//BooleanCompareSymbol/NOT_EQUALS"/>
     </genEnums>
     <genEnums typeSafeEnumCompatible="false" ecoreEnum="TestgeneratorDSL.ecore#//Flag">
+      <genEnumLiterals ecoreEnumLiteral="TestgeneratorDSL.ecore#//Flag/NONE"/>
       <genEnumLiterals ecoreEnumLiteral="TestgeneratorDSL.ecore#//Flag/GREEN"/>
       <genEnumLiterals ecoreEnumLiteral="TestgeneratorDSL.ecore#//Flag/YELLOW"/>
       <genEnumLiterals ecoreEnumLiteral="TestgeneratorDSL.ecore#//Flag/RED"/>
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.g b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.g
index b97ff630a4e4cd86692b8074babb86acec880749..dae3e2bf224927bb3d5c53a30ad9f785af283f3b 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.g
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.g
@@ -2656,11 +2656,26 @@ ruleFlowElementReference returns [EObject current=null]
 					$current = createModelElement(grammarAccess.getFlowElementReferenceRule());
 				}
 			}
-			otherlv_0=RULE_ID
-			{
-				newLeafNode(otherlv_0, grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0());
-			}
-		)
+			(
+				(
+					{
+						newCompositeNode(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0());
+					}
+					lv_flag_2_0=ruleFlag
+					{
+						if ($current==null) {
+							$current = createModelElementForParent(grammarAccess.getFlowElementReferenceRule());
+						}
+						set(
+							$current,
+							"flag",
+							lv_flag_2_0,
+							"de.fhmuenster.masterthesis.TestgeneratorDSL.Flag");
+						afterParserOrEnumRuleCall();
+					}
+				)
+			)
+		)?
 	)
 ;
 
@@ -5674,26 +5689,34 @@ ruleFlag returns [Enumerator current=null]
 }:
 	(
 		(
-			enumLiteral_0='GREEN'
+			enumLiteral_0='NONE'
+			{
+				$current = grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
+				newLeafNode(enumLiteral_0, grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0());
+			}
+		)
+		    |
+		(
+			enumLiteral_1='GREEN'
 			{
-				$current = grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
-				newLeafNode(enumLiteral_0, grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0());
+				$current = grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
+				newLeafNode(enumLiteral_1, grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1());
 			}
 		)
 		    |
 		(
-			enumLiteral_1='YELLOW'
+			enumLiteral_2='YELLOW'
 			{
-				$current = grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
-				newLeafNode(enumLiteral_1, grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1());
+				$current = grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2().getEnumLiteral().getInstance();
+				newLeafNode(enumLiteral_2, grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2());
 			}
 		)
 		    |
 		(
-			enumLiteral_2='RED'
+			enumLiteral_3='RED'
 			{
-				$current = grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2().getEnumLiteral().getInstance();
-				newLeafNode(enumLiteral_2, grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2());
+				$current = grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3().getEnumLiteral().getInstance();
+				newLeafNode(enumLiteral_3, grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3());
 			}
 		)
 	)
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.tokens b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.tokens
index ccfec6455c7d9d5e5fed628d02520b1a886e0300..f517cdd1cc85c74c46a54fd8facb5b9c9f282b27 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.tokens
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSL.tokens
@@ -1,74 +1,73 @@
-'!='=69
-'<'=80
-'<='=82
-'='=67
-'=='=68
-'>'=81
-'>='=83
+'!='=67
+'<'=78
+'<='=80
+'='=65
+'=='=66
+'>'=79
+'>='=81
 'BPMNDiagram'=16
-'Boolean'=48
-'BusinessRuleTask'=39
-'DelegateMock'=72
-'EndEvent'=28
-'ExternalServiceMock'=70
-'ExternalTopic'=44
-'Flow'=57
+'Boolean'=46
+'BusinessRuleTask'=37
+'DelegateMock'=70
+'EndEvent'=26
+'ExternalServiceMock'=68
+'ExternalTopic'=42
+'Flow'=55
 'FlowElement'=23
-'GREEN'=84
-'Gateway'=41
-'Integer'=47
-'Loop'=49
-'ManualTask'=34
-'RED'=86
-'ScriptTask'=35
-'SequenceFlow'=42
-'ServiceTask'=36
+'GREEN'=83
+'Gateway'=39
+'Integer'=45
+'Loop'=47
+'ManualTask'=30
+'NONE'=82
+'RED'=85
+'ScriptTask'=31
+'SequenceFlow'=40
+'ServiceTask'=32
 'StartEvent'=24
-'String'=45
-'Test'=62
-'UserTask'=29
-'YELLOW'=85
-'and'=32
+'String'=43
+'Test'=60
+'UserTask'=27
+'YELLOW'=84
+'and'=28
 'bpmn'=19
-'by'=52
-'check'=66
-'complexity'=55
-'delegate'=37
+'by'=50
+'check'=64
+'complexity'=53
+'delegate'=33
 'dmn'=21
-'elements'=60
+'elements'=58
 'embedded'=22
-'ends'=53
-'expression'=43
-'external'=38
-'false'=79
-'flag'=59
-'follows'=51
-'for'=58
-'hardcoded'=25
-'has'=54
-'if'=74
-'inputVariables'=30
-'inputs'=26
+'ends'=51
+'expression'=41
+'external'=34
+'false'=77
+'flag'=57
+'follows'=49
+'for'=56
+'hardcoded'=35
+'has'=52
+'if'=72
+'inputVariables'=25
+'inputs'=36
 'key'=20
-'label'=33
-'manual'=76
-'mocks'=64
-'outputVariables'=31
-'passed'=56
-'priority'=63
-'proposals'=46
-'resultVariable'=40
-'rule'=73
-'set'=75
-'setter'=77
-'startVariables'=27
-'starts'=50
+'label'=29
+'manual'=74
+'mocks'=62
+'passed'=54
+'priority'=61
+'proposals'=44
+'resultVariable'=38
+'rule'=71
+'set'=73
+'setter'=75
+'starts'=48
 'testpackage'=18
-'topic'=71
-'true'=78
-'variables'=65
+'topic'=69
+'true'=76
+'variables'=63
 'with'=17
-'without'=61
+'without'=59
 RULE_ANY_OTHER=15
 RULE_ASSOCIATION=6
 RULE_DECLARATION_FINISHED=10
@@ -151,4 +150,3 @@ T__82=82
 T__83=83
 T__84=84
 T__85=85
-T__86=86
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLLexer.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLLexer.java
index f93dd13505c70c30170fae38a73e874971accc98..4a7aa9c0f6accec9ab746b0013c3c5ec32195f99 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLLexer.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLLexer.java
@@ -94,7 +94,6 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
     public static final int T__41=41;
     public static final int T__85=85;
     public static final int T__42=42;
-    public static final int T__86=86;
     public static final int T__43=43;
 
     // delegates
@@ -304,10 +303,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__25;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:20:7: ( 'hardcoded' )
-            // InternalTestgeneratorDSL.g:20:9: 'hardcoded'
+            // InternalTestgeneratorDSL.g:20:7: ( 'inputVariables' )
+            // InternalTestgeneratorDSL.g:20:9: 'inputVariables'
             {
-            match("hardcoded"); 
+            match("inputVariables"); 
 
 
             }
@@ -325,10 +324,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__26;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:21:7: ( 'inputs' )
-            // InternalTestgeneratorDSL.g:21:9: 'inputs'
+            // InternalTestgeneratorDSL.g:21:7: ( 'EndEvent' )
+            // InternalTestgeneratorDSL.g:21:9: 'EndEvent'
             {
-            match("inputs"); 
+            match("EndEvent"); 
 
 
             }
@@ -346,10 +345,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__27;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:22:7: ( 'startVariables' )
-            // InternalTestgeneratorDSL.g:22:9: 'startVariables'
+            // InternalTestgeneratorDSL.g:22:7: ( 'UserTask' )
+            // InternalTestgeneratorDSL.g:22:9: 'UserTask'
             {
-            match("startVariables"); 
+            match("UserTask"); 
 
 
             }
@@ -367,10 +366,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__28;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:23:7: ( 'EndEvent' )
-            // InternalTestgeneratorDSL.g:23:9: 'EndEvent'
+            // InternalTestgeneratorDSL.g:23:7: ( 'and' )
+            // InternalTestgeneratorDSL.g:23:9: 'and'
             {
-            match("EndEvent"); 
+            match("and"); 
 
 
             }
@@ -388,10 +387,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__29;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:24:7: ( 'UserTask' )
-            // InternalTestgeneratorDSL.g:24:9: 'UserTask'
+            // InternalTestgeneratorDSL.g:24:7: ( 'label' )
+            // InternalTestgeneratorDSL.g:24:9: 'label'
             {
-            match("UserTask"); 
+            match("label"); 
 
 
             }
@@ -409,10 +408,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__30;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:25:7: ( 'inputVariables' )
-            // InternalTestgeneratorDSL.g:25:9: 'inputVariables'
+            // InternalTestgeneratorDSL.g:25:7: ( 'ManualTask' )
+            // InternalTestgeneratorDSL.g:25:9: 'ManualTask'
             {
-            match("inputVariables"); 
+            match("ManualTask"); 
 
 
             }
@@ -430,10 +429,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__31;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:26:7: ( 'outputVariables' )
-            // InternalTestgeneratorDSL.g:26:9: 'outputVariables'
+            // InternalTestgeneratorDSL.g:26:7: ( 'ScriptTask' )
+            // InternalTestgeneratorDSL.g:26:9: 'ScriptTask'
             {
-            match("outputVariables"); 
+            match("ScriptTask"); 
 
 
             }
@@ -451,10 +450,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__32;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:27:7: ( 'and' )
-            // InternalTestgeneratorDSL.g:27:9: 'and'
+            // InternalTestgeneratorDSL.g:27:7: ( 'ServiceTask' )
+            // InternalTestgeneratorDSL.g:27:9: 'ServiceTask'
             {
-            match("and"); 
+            match("ServiceTask"); 
 
 
             }
@@ -472,10 +471,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__33;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:28:7: ( 'label' )
-            // InternalTestgeneratorDSL.g:28:9: 'label'
+            // InternalTestgeneratorDSL.g:28:7: ( 'delegate' )
+            // InternalTestgeneratorDSL.g:28:9: 'delegate'
             {
-            match("label"); 
+            match("delegate"); 
 
 
             }
@@ -493,10 +492,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__34;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:29:7: ( 'ManualTask' )
-            // InternalTestgeneratorDSL.g:29:9: 'ManualTask'
+            // InternalTestgeneratorDSL.g:29:7: ( 'external' )
+            // InternalTestgeneratorDSL.g:29:9: 'external'
             {
-            match("ManualTask"); 
+            match("external"); 
 
 
             }
@@ -514,10 +513,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__35;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:30:7: ( 'ScriptTask' )
-            // InternalTestgeneratorDSL.g:30:9: 'ScriptTask'
+            // InternalTestgeneratorDSL.g:30:7: ( 'hardcoded' )
+            // InternalTestgeneratorDSL.g:30:9: 'hardcoded'
             {
-            match("ScriptTask"); 
+            match("hardcoded"); 
 
 
             }
@@ -535,10 +534,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__36;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:31:7: ( 'ServiceTask' )
-            // InternalTestgeneratorDSL.g:31:9: 'ServiceTask'
+            // InternalTestgeneratorDSL.g:31:7: ( 'inputs' )
+            // InternalTestgeneratorDSL.g:31:9: 'inputs'
             {
-            match("ServiceTask"); 
+            match("inputs"); 
 
 
             }
@@ -556,10 +555,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__37;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:32:7: ( 'delegate' )
-            // InternalTestgeneratorDSL.g:32:9: 'delegate'
+            // InternalTestgeneratorDSL.g:32:7: ( 'BusinessRuleTask' )
+            // InternalTestgeneratorDSL.g:32:9: 'BusinessRuleTask'
             {
-            match("delegate"); 
+            match("BusinessRuleTask"); 
 
 
             }
@@ -577,10 +576,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__38;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:33:7: ( 'external' )
-            // InternalTestgeneratorDSL.g:33:9: 'external'
+            // InternalTestgeneratorDSL.g:33:7: ( 'resultVariable' )
+            // InternalTestgeneratorDSL.g:33:9: 'resultVariable'
             {
-            match("external"); 
+            match("resultVariable"); 
 
 
             }
@@ -598,10 +597,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__39;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:34:7: ( 'BusinessRuleTask' )
-            // InternalTestgeneratorDSL.g:34:9: 'BusinessRuleTask'
+            // InternalTestgeneratorDSL.g:34:7: ( 'Gateway' )
+            // InternalTestgeneratorDSL.g:34:9: 'Gateway'
             {
-            match("BusinessRuleTask"); 
+            match("Gateway"); 
 
 
             }
@@ -619,10 +618,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__40;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:35:7: ( 'resultVariable' )
-            // InternalTestgeneratorDSL.g:35:9: 'resultVariable'
+            // InternalTestgeneratorDSL.g:35:7: ( 'SequenceFlow' )
+            // InternalTestgeneratorDSL.g:35:9: 'SequenceFlow'
             {
-            match("resultVariable"); 
+            match("SequenceFlow"); 
 
 
             }
@@ -640,10 +639,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__41;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:36:7: ( 'Gateway' )
-            // InternalTestgeneratorDSL.g:36:9: 'Gateway'
+            // InternalTestgeneratorDSL.g:36:7: ( 'expression' )
+            // InternalTestgeneratorDSL.g:36:9: 'expression'
             {
-            match("Gateway"); 
+            match("expression"); 
 
 
             }
@@ -661,10 +660,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__42;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:37:7: ( 'SequenceFlow' )
-            // InternalTestgeneratorDSL.g:37:9: 'SequenceFlow'
+            // InternalTestgeneratorDSL.g:37:7: ( 'ExternalTopic' )
+            // InternalTestgeneratorDSL.g:37:9: 'ExternalTopic'
             {
-            match("SequenceFlow"); 
+            match("ExternalTopic"); 
 
 
             }
@@ -682,10 +681,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__43;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:38:7: ( 'expression' )
-            // InternalTestgeneratorDSL.g:38:9: 'expression'
+            // InternalTestgeneratorDSL.g:38:7: ( 'String' )
+            // InternalTestgeneratorDSL.g:38:9: 'String'
             {
-            match("expression"); 
+            match("String"); 
 
 
             }
@@ -703,10 +702,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__44;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:39:7: ( 'ExternalTopic' )
-            // InternalTestgeneratorDSL.g:39:9: 'ExternalTopic'
+            // InternalTestgeneratorDSL.g:39:7: ( 'proposals' )
+            // InternalTestgeneratorDSL.g:39:9: 'proposals'
             {
-            match("ExternalTopic"); 
+            match("proposals"); 
 
 
             }
@@ -724,10 +723,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__45;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:40:7: ( 'String' )
-            // InternalTestgeneratorDSL.g:40:9: 'String'
+            // InternalTestgeneratorDSL.g:40:7: ( 'Integer' )
+            // InternalTestgeneratorDSL.g:40:9: 'Integer'
             {
-            match("String"); 
+            match("Integer"); 
 
 
             }
@@ -745,10 +744,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__46;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:41:7: ( 'proposals' )
-            // InternalTestgeneratorDSL.g:41:9: 'proposals'
+            // InternalTestgeneratorDSL.g:41:7: ( 'Boolean' )
+            // InternalTestgeneratorDSL.g:41:9: 'Boolean'
             {
-            match("proposals"); 
+            match("Boolean"); 
 
 
             }
@@ -766,10 +765,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__47;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:42:7: ( 'Integer' )
-            // InternalTestgeneratorDSL.g:42:9: 'Integer'
+            // InternalTestgeneratorDSL.g:42:7: ( 'Loop' )
+            // InternalTestgeneratorDSL.g:42:9: 'Loop'
             {
-            match("Integer"); 
+            match("Loop"); 
 
 
             }
@@ -787,10 +786,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__48;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:43:7: ( 'Boolean' )
-            // InternalTestgeneratorDSL.g:43:9: 'Boolean'
+            // InternalTestgeneratorDSL.g:43:7: ( 'starts' )
+            // InternalTestgeneratorDSL.g:43:9: 'starts'
             {
-            match("Boolean"); 
+            match("starts"); 
 
 
             }
@@ -808,10 +807,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__49;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:44:7: ( 'Loop' )
-            // InternalTestgeneratorDSL.g:44:9: 'Loop'
+            // InternalTestgeneratorDSL.g:44:7: ( 'follows' )
+            // InternalTestgeneratorDSL.g:44:9: 'follows'
             {
-            match("Loop"); 
+            match("follows"); 
 
 
             }
@@ -829,10 +828,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__50;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:45:7: ( 'starts' )
-            // InternalTestgeneratorDSL.g:45:9: 'starts'
+            // InternalTestgeneratorDSL.g:45:7: ( 'by' )
+            // InternalTestgeneratorDSL.g:45:9: 'by'
             {
-            match("starts"); 
+            match("by"); 
 
 
             }
@@ -850,10 +849,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__51;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:46:7: ( 'follows' )
-            // InternalTestgeneratorDSL.g:46:9: 'follows'
+            // InternalTestgeneratorDSL.g:46:7: ( 'ends' )
+            // InternalTestgeneratorDSL.g:46:9: 'ends'
             {
-            match("follows"); 
+            match("ends"); 
 
 
             }
@@ -871,10 +870,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__52;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:47:7: ( 'by' )
-            // InternalTestgeneratorDSL.g:47:9: 'by'
+            // InternalTestgeneratorDSL.g:47:7: ( 'has' )
+            // InternalTestgeneratorDSL.g:47:9: 'has'
             {
-            match("by"); 
+            match("has"); 
 
 
             }
@@ -892,10 +891,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__53;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:48:7: ( 'ends' )
-            // InternalTestgeneratorDSL.g:48:9: 'ends'
+            // InternalTestgeneratorDSL.g:48:7: ( 'complexity' )
+            // InternalTestgeneratorDSL.g:48:9: 'complexity'
             {
-            match("ends"); 
+            match("complexity"); 
 
 
             }
@@ -913,10 +912,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__54;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:49:7: ( 'has' )
-            // InternalTestgeneratorDSL.g:49:9: 'has'
+            // InternalTestgeneratorDSL.g:49:7: ( 'passed' )
+            // InternalTestgeneratorDSL.g:49:9: 'passed'
             {
-            match("has"); 
+            match("passed"); 
 
 
             }
@@ -934,10 +933,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__55;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:50:7: ( 'complexity' )
-            // InternalTestgeneratorDSL.g:50:9: 'complexity'
+            // InternalTestgeneratorDSL.g:50:7: ( 'Flow' )
+            // InternalTestgeneratorDSL.g:50:9: 'Flow'
             {
-            match("complexity"); 
+            match("Flow"); 
 
 
             }
@@ -955,10 +954,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__56;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:51:7: ( 'passed' )
-            // InternalTestgeneratorDSL.g:51:9: 'passed'
+            // InternalTestgeneratorDSL.g:51:7: ( 'for' )
+            // InternalTestgeneratorDSL.g:51:9: 'for'
             {
-            match("passed"); 
+            match("for"); 
 
 
             }
@@ -976,10 +975,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__57;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:52:7: ( 'Flow' )
-            // InternalTestgeneratorDSL.g:52:9: 'Flow'
+            // InternalTestgeneratorDSL.g:52:7: ( 'flag' )
+            // InternalTestgeneratorDSL.g:52:9: 'flag'
             {
-            match("Flow"); 
+            match("flag"); 
 
 
             }
@@ -997,10 +996,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__58;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:53:7: ( 'for' )
-            // InternalTestgeneratorDSL.g:53:9: 'for'
+            // InternalTestgeneratorDSL.g:53:7: ( 'elements' )
+            // InternalTestgeneratorDSL.g:53:9: 'elements'
             {
-            match("for"); 
+            match("elements"); 
 
 
             }
@@ -1018,10 +1017,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__59;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:54:7: ( 'flag' )
-            // InternalTestgeneratorDSL.g:54:9: 'flag'
+            // InternalTestgeneratorDSL.g:54:7: ( 'without' )
+            // InternalTestgeneratorDSL.g:54:9: 'without'
             {
-            match("flag"); 
+            match("without"); 
 
 
             }
@@ -1039,10 +1038,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__60;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:55:7: ( 'elements' )
-            // InternalTestgeneratorDSL.g:55:9: 'elements'
+            // InternalTestgeneratorDSL.g:55:7: ( 'Test' )
+            // InternalTestgeneratorDSL.g:55:9: 'Test'
             {
-            match("elements"); 
+            match("Test"); 
 
 
             }
@@ -1060,10 +1059,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__61;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:56:7: ( 'without' )
-            // InternalTestgeneratorDSL.g:56:9: 'without'
+            // InternalTestgeneratorDSL.g:56:7: ( 'priority' )
+            // InternalTestgeneratorDSL.g:56:9: 'priority'
             {
-            match("without"); 
+            match("priority"); 
 
 
             }
@@ -1081,10 +1080,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__62;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:57:7: ( 'Test' )
-            // InternalTestgeneratorDSL.g:57:9: 'Test'
+            // InternalTestgeneratorDSL.g:57:7: ( 'mocks' )
+            // InternalTestgeneratorDSL.g:57:9: 'mocks'
             {
-            match("Test"); 
+            match("mocks"); 
 
 
             }
@@ -1102,10 +1101,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__63;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:58:7: ( 'priority' )
-            // InternalTestgeneratorDSL.g:58:9: 'priority'
+            // InternalTestgeneratorDSL.g:58:7: ( 'variables' )
+            // InternalTestgeneratorDSL.g:58:9: 'variables'
             {
-            match("priority"); 
+            match("variables"); 
 
 
             }
@@ -1123,10 +1122,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__64;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:59:7: ( 'mocks' )
-            // InternalTestgeneratorDSL.g:59:9: 'mocks'
+            // InternalTestgeneratorDSL.g:59:7: ( 'check' )
+            // InternalTestgeneratorDSL.g:59:9: 'check'
             {
-            match("mocks"); 
+            match("check"); 
 
 
             }
@@ -1144,11 +1143,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__65;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:60:7: ( 'variables' )
-            // InternalTestgeneratorDSL.g:60:9: 'variables'
+            // InternalTestgeneratorDSL.g:60:7: ( '=' )
+            // InternalTestgeneratorDSL.g:60:9: '='
             {
-            match("variables"); 
-
+            match('='); 
 
             }
 
@@ -1165,10 +1163,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__66;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:61:7: ( 'check' )
-            // InternalTestgeneratorDSL.g:61:9: 'check'
+            // InternalTestgeneratorDSL.g:61:7: ( '==' )
+            // InternalTestgeneratorDSL.g:61:9: '=='
             {
-            match("check"); 
+            match("=="); 
 
 
             }
@@ -1186,10 +1184,11 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__67;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:62:7: ( '=' )
-            // InternalTestgeneratorDSL.g:62:9: '='
+            // InternalTestgeneratorDSL.g:62:7: ( '!=' )
+            // InternalTestgeneratorDSL.g:62:9: '!='
             {
-            match('='); 
+            match("!="); 
+
 
             }
 
@@ -1206,10 +1205,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__68;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:63:7: ( '==' )
-            // InternalTestgeneratorDSL.g:63:9: '=='
+            // InternalTestgeneratorDSL.g:63:7: ( 'ExternalServiceMock' )
+            // InternalTestgeneratorDSL.g:63:9: 'ExternalServiceMock'
             {
-            match("=="); 
+            match("ExternalServiceMock"); 
 
 
             }
@@ -1227,10 +1226,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__69;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:64:7: ( '!=' )
-            // InternalTestgeneratorDSL.g:64:9: '!='
+            // InternalTestgeneratorDSL.g:64:7: ( 'topic' )
+            // InternalTestgeneratorDSL.g:64:9: 'topic'
             {
-            match("!="); 
+            match("topic"); 
 
 
             }
@@ -1248,10 +1247,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__70;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:65:7: ( 'ExternalServiceMock' )
-            // InternalTestgeneratorDSL.g:65:9: 'ExternalServiceMock'
+            // InternalTestgeneratorDSL.g:65:7: ( 'DelegateMock' )
+            // InternalTestgeneratorDSL.g:65:9: 'DelegateMock'
             {
-            match("ExternalServiceMock"); 
+            match("DelegateMock"); 
 
 
             }
@@ -1269,10 +1268,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__71;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:66:7: ( 'topic' )
-            // InternalTestgeneratorDSL.g:66:9: 'topic'
+            // InternalTestgeneratorDSL.g:66:7: ( 'rule' )
+            // InternalTestgeneratorDSL.g:66:9: 'rule'
             {
-            match("topic"); 
+            match("rule"); 
 
 
             }
@@ -1290,10 +1289,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__72;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:67:7: ( 'DelegateMock' )
-            // InternalTestgeneratorDSL.g:67:9: 'DelegateMock'
+            // InternalTestgeneratorDSL.g:67:7: ( 'if' )
+            // InternalTestgeneratorDSL.g:67:9: 'if'
             {
-            match("DelegateMock"); 
+            match("if"); 
 
 
             }
@@ -1311,10 +1310,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__73;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:68:7: ( 'rule' )
-            // InternalTestgeneratorDSL.g:68:9: 'rule'
+            // InternalTestgeneratorDSL.g:68:7: ( 'set' )
+            // InternalTestgeneratorDSL.g:68:9: 'set'
             {
-            match("rule"); 
+            match("set"); 
 
 
             }
@@ -1332,10 +1331,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__74;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:69:7: ( 'if' )
-            // InternalTestgeneratorDSL.g:69:9: 'if'
+            // InternalTestgeneratorDSL.g:69:7: ( 'manual' )
+            // InternalTestgeneratorDSL.g:69:9: 'manual'
             {
-            match("if"); 
+            match("manual"); 
 
 
             }
@@ -1353,10 +1352,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__75;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:70:7: ( 'set' )
-            // InternalTestgeneratorDSL.g:70:9: 'set'
+            // InternalTestgeneratorDSL.g:70:7: ( 'setter' )
+            // InternalTestgeneratorDSL.g:70:9: 'setter'
             {
-            match("set"); 
+            match("setter"); 
 
 
             }
@@ -1374,10 +1373,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__76;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:71:7: ( 'manual' )
-            // InternalTestgeneratorDSL.g:71:9: 'manual'
+            // InternalTestgeneratorDSL.g:71:7: ( 'true' )
+            // InternalTestgeneratorDSL.g:71:9: 'true'
             {
-            match("manual"); 
+            match("true"); 
 
 
             }
@@ -1395,10 +1394,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__77;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:72:7: ( 'setter' )
-            // InternalTestgeneratorDSL.g:72:9: 'setter'
+            // InternalTestgeneratorDSL.g:72:7: ( 'false' )
+            // InternalTestgeneratorDSL.g:72:9: 'false'
             {
-            match("setter"); 
+            match("false"); 
 
 
             }
@@ -1416,11 +1415,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__78;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:73:7: ( 'true' )
-            // InternalTestgeneratorDSL.g:73:9: 'true'
+            // InternalTestgeneratorDSL.g:73:7: ( '<' )
+            // InternalTestgeneratorDSL.g:73:9: '<'
             {
-            match("true"); 
-
+            match('<'); 
 
             }
 
@@ -1437,11 +1435,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__79;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:74:7: ( 'false' )
-            // InternalTestgeneratorDSL.g:74:9: 'false'
+            // InternalTestgeneratorDSL.g:74:7: ( '>' )
+            // InternalTestgeneratorDSL.g:74:9: '>'
             {
-            match("false"); 
-
+            match('>'); 
 
             }
 
@@ -1458,10 +1455,11 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__80;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:75:7: ( '<' )
-            // InternalTestgeneratorDSL.g:75:9: '<'
+            // InternalTestgeneratorDSL.g:75:7: ( '<=' )
+            // InternalTestgeneratorDSL.g:75:9: '<='
             {
-            match('<'); 
+            match("<="); 
+
 
             }
 
@@ -1478,10 +1476,11 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__81;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:76:7: ( '>' )
-            // InternalTestgeneratorDSL.g:76:9: '>'
+            // InternalTestgeneratorDSL.g:76:7: ( '>=' )
+            // InternalTestgeneratorDSL.g:76:9: '>='
             {
-            match('>'); 
+            match(">="); 
+
 
             }
 
@@ -1498,10 +1497,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__82;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:77:7: ( '<=' )
-            // InternalTestgeneratorDSL.g:77:9: '<='
+            // InternalTestgeneratorDSL.g:77:7: ( 'NONE' )
+            // InternalTestgeneratorDSL.g:77:9: 'NONE'
             {
-            match("<="); 
+            match("NONE"); 
 
 
             }
@@ -1519,10 +1518,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__83;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:78:7: ( '>=' )
-            // InternalTestgeneratorDSL.g:78:9: '>='
+            // InternalTestgeneratorDSL.g:78:7: ( 'GREEN' )
+            // InternalTestgeneratorDSL.g:78:9: 'GREEN'
             {
-            match(">="); 
+            match("GREEN"); 
 
 
             }
@@ -1540,10 +1539,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__84;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:79:7: ( 'GREEN' )
-            // InternalTestgeneratorDSL.g:79:9: 'GREEN'
+            // InternalTestgeneratorDSL.g:79:7: ( 'YELLOW' )
+            // InternalTestgeneratorDSL.g:79:9: 'YELLOW'
             {
-            match("GREEN"); 
+            match("YELLOW"); 
 
 
             }
@@ -1561,29 +1560,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = T__85;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:80:7: ( 'YELLOW' )
-            // InternalTestgeneratorDSL.g:80:9: 'YELLOW'
-            {
-            match("YELLOW"); 
-
-
-            }
-
-            state.type = _type;
-            state.channel = _channel;
-        }
-        finally {
-        }
-    }
-    // $ANTLR end "T__85"
-
-    // $ANTLR start "T__86"
-    public final void mT__86() throws RecognitionException {
-        try {
-            int _type = T__86;
-            int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:81:7: ( 'RED' )
-            // InternalTestgeneratorDSL.g:81:9: 'RED'
+            // InternalTestgeneratorDSL.g:80:7: ( 'RED' )
+            // InternalTestgeneratorDSL.g:80:9: 'RED'
             {
             match("RED"); 
 
@@ -1596,15 +1574,15 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         finally {
         }
     }
-    // $ANTLR end "T__86"
+    // $ANTLR end "T__85"
 
     // $ANTLR start "RULE_LIST_OPEN"
     public final void mRULE_LIST_OPEN() throws RecognitionException {
         try {
             int _type = RULE_LIST_OPEN;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5702:16: ( '[' )
-            // InternalTestgeneratorDSL.g:5702:18: '['
+            // InternalTestgeneratorDSL.g:4765:16: ( '[' )
+            // InternalTestgeneratorDSL.g:4765:18: '['
             {
             match('['); 
 
@@ -1623,8 +1601,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_LIST_CLOSED;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5704:18: ( ']' )
-            // InternalTestgeneratorDSL.g:5704:20: ']'
+            // InternalTestgeneratorDSL.g:4767:18: ( ']' )
+            // InternalTestgeneratorDSL.g:4767:20: ']'
             {
             match(']'); 
 
@@ -1643,8 +1621,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ASSOCIATION;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5706:18: ( ':' )
-            // InternalTestgeneratorDSL.g:5706:20: ':'
+            // InternalTestgeneratorDSL.g:4769:18: ( ':' )
+            // InternalTestgeneratorDSL.g:4769:20: ':'
             {
             match(':'); 
 
@@ -1663,8 +1641,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_SEPARATOR;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5708:16: ( ',' )
-            // InternalTestgeneratorDSL.g:5708:18: ','
+            // InternalTestgeneratorDSL.g:4771:16: ( ',' )
+            // InternalTestgeneratorDSL.g:4771:18: ','
             {
             match(','); 
 
@@ -1683,8 +1661,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_DECLARATION_FINISHED;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5710:27: ( ';' )
-            // InternalTestgeneratorDSL.g:5710:29: ';'
+            // InternalTestgeneratorDSL.g:4773:27: ( ';' )
+            // InternalTestgeneratorDSL.g:4773:29: ';'
             {
             match(';'); 
 
@@ -1703,10 +1681,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ID;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5712:9: ( ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )* )
-            // InternalTestgeneratorDSL.g:5712:11: ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
+            // InternalTestgeneratorDSL.g:4775:9: ( ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )* )
+            // InternalTestgeneratorDSL.g:4775:11: ( '^' )? ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '-' ) ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
             {
-            // InternalTestgeneratorDSL.g:5712:11: ( '^' )?
+            // InternalTestgeneratorDSL.g:4775:11: ( '^' )?
             int alt1=2;
             int LA1_0 = input.LA(1);
 
@@ -1715,7 +1693,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt1) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5712:11: '^'
+                    // InternalTestgeneratorDSL.g:4775:11: '^'
                     {
                     match('^'); 
 
@@ -1733,7 +1711,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 recover(mse);
                 throw mse;}
 
-            // InternalTestgeneratorDSL.g:5712:44: ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
+            // InternalTestgeneratorDSL.g:4775:44: ( 'a' .. 'z' | 'A' .. 'Z' | '_' | '0' .. '9' | '-' )*
             loop2:
             do {
                 int alt2=2;
@@ -1782,10 +1760,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_INT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5714:10: ( ( '0' .. '9' )+ )
-            // InternalTestgeneratorDSL.g:5714:12: ( '0' .. '9' )+
+            // InternalTestgeneratorDSL.g:4777:10: ( ( '0' .. '9' )+ )
+            // InternalTestgeneratorDSL.g:4777:12: ( '0' .. '9' )+
             {
-            // InternalTestgeneratorDSL.g:5714:12: ( '0' .. '9' )+
+            // InternalTestgeneratorDSL.g:4777:12: ( '0' .. '9' )+
             int cnt3=0;
             loop3:
             do {
@@ -1799,7 +1777,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt3) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:5714:13: '0' .. '9'
+            	    // InternalTestgeneratorDSL.g:4777:13: '0' .. '9'
             	    {
             	    matchRange('0','9'); 
 
@@ -1831,10 +1809,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_STRING;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5716:13: ( ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' ) )
-            // InternalTestgeneratorDSL.g:5716:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
+            // InternalTestgeneratorDSL.g:4779:13: ( ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' ) )
+            // InternalTestgeneratorDSL.g:4779:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
             {
-            // InternalTestgeneratorDSL.g:5716:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
+            // InternalTestgeneratorDSL.g:4779:15: ( '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"' | '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\'' )
             int alt6=2;
             int LA6_0 = input.LA(1);
 
@@ -1852,10 +1830,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt6) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5716:16: '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"'
+                    // InternalTestgeneratorDSL.g:4779:16: '\"' ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )* '\"'
                     {
                     match('\"'); 
-                    // InternalTestgeneratorDSL.g:5716:20: ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )*
+                    // InternalTestgeneratorDSL.g:4779:20: ( '\\\\' . | ~ ( ( '\\\\' | '\"' ) ) )*
                     loop4:
                     do {
                         int alt4=3;
@@ -1871,7 +1849,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         switch (alt4) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:5716:21: '\\\\' .
+                    	    // InternalTestgeneratorDSL.g:4779:21: '\\\\' .
                     	    {
                     	    match('\\'); 
                     	    matchAny(); 
@@ -1879,7 +1857,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     	    }
                     	    break;
                     	case 2 :
-                    	    // InternalTestgeneratorDSL.g:5716:28: ~ ( ( '\\\\' | '\"' ) )
+                    	    // InternalTestgeneratorDSL.g:4779:28: ~ ( ( '\\\\' | '\"' ) )
                     	    {
                     	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='!')||(input.LA(1)>='#' && input.LA(1)<='[')||(input.LA(1)>=']' && input.LA(1)<='\uFFFF') ) {
                     	        input.consume();
@@ -1904,10 +1882,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5716:48: '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\''
+                    // InternalTestgeneratorDSL.g:4779:48: '\\'' ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )* '\\''
                     {
                     match('\''); 
-                    // InternalTestgeneratorDSL.g:5716:53: ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )*
+                    // InternalTestgeneratorDSL.g:4779:53: ( '\\\\' . | ~ ( ( '\\\\' | '\\'' ) ) )*
                     loop5:
                     do {
                         int alt5=3;
@@ -1923,7 +1901,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         switch (alt5) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:5716:54: '\\\\' .
+                    	    // InternalTestgeneratorDSL.g:4779:54: '\\\\' .
                     	    {
                     	    match('\\'); 
                     	    matchAny(); 
@@ -1931,7 +1909,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     	    }
                     	    break;
                     	case 2 :
-                    	    // InternalTestgeneratorDSL.g:5716:61: ~ ( ( '\\\\' | '\\'' ) )
+                    	    // InternalTestgeneratorDSL.g:4779:61: ~ ( ( '\\\\' | '\\'' ) )
                     	    {
                     	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='&')||(input.LA(1)>='(' && input.LA(1)<='[')||(input.LA(1)>=']' && input.LA(1)<='\uFFFF') ) {
                     	        input.consume();
@@ -1974,12 +1952,12 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ML_COMMENT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5718:17: ( '/*' ( options {greedy=false; } : . )* '*/' )
-            // InternalTestgeneratorDSL.g:5718:19: '/*' ( options {greedy=false; } : . )* '*/'
+            // InternalTestgeneratorDSL.g:4781:17: ( '/*' ( options {greedy=false; } : . )* '*/' )
+            // InternalTestgeneratorDSL.g:4781:19: '/*' ( options {greedy=false; } : . )* '*/'
             {
             match("/*"); 
 
-            // InternalTestgeneratorDSL.g:5718:24: ( options {greedy=false; } : . )*
+            // InternalTestgeneratorDSL.g:4781:24: ( options {greedy=false; } : . )*
             loop7:
             do {
                 int alt7=2;
@@ -2004,7 +1982,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt7) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:5718:52: .
+            	    // InternalTestgeneratorDSL.g:4781:52: .
             	    {
             	    matchAny(); 
 
@@ -2034,12 +2012,12 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_SL_COMMENT;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5720:17: ( '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )? )
-            // InternalTestgeneratorDSL.g:5720:19: '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )?
+            // InternalTestgeneratorDSL.g:4783:17: ( '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )? )
+            // InternalTestgeneratorDSL.g:4783:19: '//' (~ ( ( '\\n' | '\\r' ) ) )* ( ( '\\r' )? '\\n' )?
             {
             match("//"); 
 
-            // InternalTestgeneratorDSL.g:5720:24: (~ ( ( '\\n' | '\\r' ) ) )*
+            // InternalTestgeneratorDSL.g:4783:24: (~ ( ( '\\n' | '\\r' ) ) )*
             loop8:
             do {
                 int alt8=2;
@@ -2052,7 +2030,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                 switch (alt8) {
             	case 1 :
-            	    // InternalTestgeneratorDSL.g:5720:24: ~ ( ( '\\n' | '\\r' ) )
+            	    // InternalTestgeneratorDSL.g:4783:24: ~ ( ( '\\n' | '\\r' ) )
             	    {
             	    if ( (input.LA(1)>='\u0000' && input.LA(1)<='\t')||(input.LA(1)>='\u000B' && input.LA(1)<='\f')||(input.LA(1)>='\u000E' && input.LA(1)<='\uFFFF') ) {
             	        input.consume();
@@ -2072,7 +2050,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 }
             } while (true);
 
-            // InternalTestgeneratorDSL.g:5720:40: ( ( '\\r' )? '\\n' )?
+            // InternalTestgeneratorDSL.g:4783:40: ( ( '\\r' )? '\\n' )?
             int alt10=2;
             int LA10_0 = input.LA(1);
 
@@ -2081,9 +2059,9 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             }
             switch (alt10) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5720:41: ( '\\r' )? '\\n'
+                    // InternalTestgeneratorDSL.g:4783:41: ( '\\r' )? '\\n'
                     {
-                    // InternalTestgeneratorDSL.g:5720:41: ( '\\r' )?
+                    // InternalTestgeneratorDSL.g:4783:41: ( '\\r' )?
                     int alt9=2;
                     int LA9_0 = input.LA(1);
 
@@ -2092,7 +2070,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                     }
                     switch (alt9) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:5720:41: '\\r'
+                            // InternalTestgeneratorDSL.g:4783:41: '\\r'
                             {
                             match('\r'); 
 
@@ -2124,10 +2102,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_WS;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5722:9: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ )
-            // InternalTestgeneratorDSL.g:5722:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
+            // InternalTestgeneratorDSL.g:4785:9: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ )
+            // InternalTestgeneratorDSL.g:4785:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
             {
-            // InternalTestgeneratorDSL.g:5722:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
+            // InternalTestgeneratorDSL.g:4785:11: ( ' ' | '\\t' | '\\r' | '\\n' )+
             int cnt11=0;
             loop11:
             do {
@@ -2181,8 +2159,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
         try {
             int _type = RULE_ANY_OTHER;
             int _channel = DEFAULT_TOKEN_CHANNEL;
-            // InternalTestgeneratorDSL.g:5724:16: ( . )
-            // InternalTestgeneratorDSL.g:5724:18: .
+            // InternalTestgeneratorDSL.g:4787:16: ( . )
+            // InternalTestgeneratorDSL.g:4787:18: .
             {
             matchAny(); 
 
@@ -2197,8 +2175,8 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
     // $ANTLR end "RULE_ANY_OTHER"
 
     public void mTokens() throws RecognitionException {
-        // InternalTestgeneratorDSL.g:1:8: ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | T__86 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER )
-        int alt12=83;
+        // InternalTestgeneratorDSL.g:1:8: ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER )
+        int alt12=82;
         alt12 = dfa12.predict(input);
         switch (alt12) {
             case 1 :
@@ -2692,91 +2670,84 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
                 }
                 break;
             case 71 :
-                // InternalTestgeneratorDSL.g:1:430: T__86
-                {
-                mT__86(); 
-
-                }
-                break;
-            case 72 :
-                // InternalTestgeneratorDSL.g:1:436: RULE_LIST_OPEN
+                // InternalTestgeneratorDSL.g:1:430: RULE_LIST_OPEN
                 {
                 mRULE_LIST_OPEN(); 
 
                 }
                 break;
-            case 73 :
-                // InternalTestgeneratorDSL.g:1:451: RULE_LIST_CLOSED
+            case 72 :
+                // InternalTestgeneratorDSL.g:1:445: RULE_LIST_CLOSED
                 {
                 mRULE_LIST_CLOSED(); 
 
                 }
                 break;
-            case 74 :
-                // InternalTestgeneratorDSL.g:1:468: RULE_ASSOCIATION
+            case 73 :
+                // InternalTestgeneratorDSL.g:1:462: RULE_ASSOCIATION
                 {
                 mRULE_ASSOCIATION(); 
 
                 }
                 break;
-            case 75 :
-                // InternalTestgeneratorDSL.g:1:485: RULE_SEPARATOR
+            case 74 :
+                // InternalTestgeneratorDSL.g:1:479: RULE_SEPARATOR
                 {
                 mRULE_SEPARATOR(); 
 
                 }
                 break;
-            case 76 :
-                // InternalTestgeneratorDSL.g:1:500: RULE_DECLARATION_FINISHED
+            case 75 :
+                // InternalTestgeneratorDSL.g:1:494: RULE_DECLARATION_FINISHED
                 {
                 mRULE_DECLARATION_FINISHED(); 
 
                 }
                 break;
-            case 77 :
-                // InternalTestgeneratorDSL.g:1:526: RULE_ID
+            case 76 :
+                // InternalTestgeneratorDSL.g:1:520: RULE_ID
                 {
                 mRULE_ID(); 
 
                 }
                 break;
-            case 78 :
-                // InternalTestgeneratorDSL.g:1:534: RULE_INT
+            case 77 :
+                // InternalTestgeneratorDSL.g:1:528: RULE_INT
                 {
                 mRULE_INT(); 
 
                 }
                 break;
-            case 79 :
-                // InternalTestgeneratorDSL.g:1:543: RULE_STRING
+            case 78 :
+                // InternalTestgeneratorDSL.g:1:537: RULE_STRING
                 {
                 mRULE_STRING(); 
 
                 }
                 break;
-            case 80 :
-                // InternalTestgeneratorDSL.g:1:555: RULE_ML_COMMENT
+            case 79 :
+                // InternalTestgeneratorDSL.g:1:549: RULE_ML_COMMENT
                 {
                 mRULE_ML_COMMENT(); 
 
                 }
                 break;
-            case 81 :
-                // InternalTestgeneratorDSL.g:1:571: RULE_SL_COMMENT
+            case 80 :
+                // InternalTestgeneratorDSL.g:1:565: RULE_SL_COMMENT
                 {
                 mRULE_SL_COMMENT(); 
 
                 }
                 break;
-            case 82 :
-                // InternalTestgeneratorDSL.g:1:587: RULE_WS
+            case 81 :
+                // InternalTestgeneratorDSL.g:1:581: RULE_WS
                 {
                 mRULE_WS(); 
 
                 }
                 break;
-            case 83 :
-                // InternalTestgeneratorDSL.g:1:595: RULE_ANY_OTHER
+            case 82 :
+                // InternalTestgeneratorDSL.g:1:589: RULE_ANY_OTHER
                 {
                 mRULE_ANY_OTHER(); 
 
@@ -2790,19 +2761,19 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
     protected DFA12 dfa12 = new DFA12(this);
     static final String DFA12_eotS =
-        "\1\uffff\34\64\1\144\1\60\1\64\1\150\1\152\2\64\5\uffff\1\60\2\uffff\3\60\2\uffff\3\64\1\uffff\5\64\1\177\15\64\1\u0091\32\64\3\uffff\1\64\4\uffff\2\64\12\uffff\10\64\1\uffff\1\u00b9\1\u00ba\15\64\1\u00c8\1\64\1\uffff\1\64\1\u00cc\4\64\1\u00d1\14\64\1\u00de\12\64\1\u00e9\3\64\1\u00ee\2\64\1\u00f1\1\u00f2\2\uffff\4\64\1\u00f7\1\64\1\u00fa\6\64\1\uffff\3\64\1\uffff\4\64\1\uffff\3\64\1\u010b\6\64\1\u0112\1\64\1\uffff\1\u0114\3\64\1\u0118\5\64\1\uffff\4\64\1\uffff\1\64\1\u0123\2\uffff\4\64\1\uffff\2\64\1\uffff\15\64\1\u0139\2\64\1\uffff\1\64\1\u013d\4\64\1\uffff\1\64\1\uffff\1\u0143\1\64\1\u0145\1\uffff\1\u0146\11\64\1\uffff\7\64\1\u0157\4\64\1\u015c\2\64\1\u015f\1\u0160\4\64\1\uffff\3\64\1\uffff\2\64\1\u016a\2\64\1\uffff\1\64\2\uffff\1\u016e\2\64\1\u0171\2\64\1\u0174\1\u0175\10\64\1\uffff\4\64\1\uffff\2\64\2\uffff\6\64\1\u018a\2\64\1\uffff\1\u018d\1\u018e\1\64\1\uffff\2\64\1\uffff\2\64\2\uffff\1\64\1\u0195\1\u0196\1\u0197\1\64\1\u0199\10\64\1\u01a2\1\64\1\u01a5\3\64\1\uffff\1\64\1\u01aa\2\uffff\6\64\3\uffff\1\64\1\uffff\5\64\1\u01b7\2\64\1\uffff\2\64\1\uffff\3\64\1\u01bf\1\uffff\1\64\1\u01c1\4\64\1\u01c6\1\64\1\u01c8\1\u01c9\2\64\1\uffff\5\64\1\u01d1\1\64\1\uffff\1\u01d3\1\uffff\1\64\1\u01d5\1\64\1\u01d7\1\uffff\1\u01d8\2\uffff\1\u01d9\6\64\1\uffff\1\64\1\uffff\1\64\1\uffff\1\64\3\uffff\1\u01e3\6\64\1\u01ea\1\64\1\uffff\2\64\1\u01ee\3\64\1\uffff\1\64\1\u01f3\1\u01f4\1\uffff\2\64\1\u01f7\1\64\2\uffff\1\64\1\u01fa\1\uffff\1\u01fb\1\64\2\uffff\2\64\1\u01ff\1\uffff";
+        "\1\uffff\33\64\1\143\1\60\1\64\1\147\1\151\3\64\5\uffff\1\60\2\uffff\3\60\2\uffff\3\64\1\uffff\5\64\1\177\14\64\1\u008f\32\64\3\uffff\1\64\4\uffff\3\64\12\uffff\10\64\1\uffff\1\u00b9\1\u00ba\15\64\1\uffff\3\64\1\u00cb\3\64\1\u00cf\12\64\1\u00db\1\64\1\u00dd\13\64\1\u00e9\3\64\1\u00ee\2\64\1\u00f1\1\u00f2\2\uffff\4\64\1\u00f7\1\64\1\u00fa\11\64\1\uffff\3\64\1\uffff\1\64\1\u0108\6\64\1\u010f\2\64\1\uffff\1\64\1\uffff\1\u0113\3\64\1\u0117\4\64\1\u011c\1\64\1\uffff\4\64\1\uffff\1\64\1\u0123\2\uffff\4\64\1\uffff\2\64\1\uffff\11\64\1\u0134\3\64\1\uffff\1\64\1\u0139\4\64\1\uffff\3\64\1\uffff\1\u0141\1\64\1\u0143\1\uffff\1\u0144\3\64\1\uffff\6\64\1\uffff\7\64\1\u0155\4\64\1\u015a\3\64\1\uffff\4\64\1\uffff\2\64\1\u0164\1\64\1\u0166\1\u0167\1\64\1\uffff\1\64\2\uffff\1\u016a\2\64\1\u016d\2\64\1\u0170\1\u0171\10\64\1\uffff\4\64\1\uffff\6\64\1\u0184\2\64\1\uffff\1\u0187\2\uffff\1\u0188\1\64\1\uffff\2\64\1\uffff\2\64\2\uffff\1\64\1\u018f\1\u0190\1\u0191\1\64\1\u0193\6\64\1\u019a\1\64\1\u019d\3\64\1\uffff\1\64\1\u01a2\2\uffff\6\64\3\uffff\1\64\1\uffff\6\64\1\uffff\2\64\1\uffff\1\64\1\u01b3\1\64\1\u01b5\1\uffff\1\64\1\u01b7\4\64\1\u01bc\1\64\1\u01be\1\u01bf\5\64\1\u01c5\1\uffff\1\64\1\uffff\1\u01c7\1\uffff\1\64\1\u01c9\1\64\1\u01cb\1\uffff\1\u01cc\2\uffff\1\u01cd\4\64\1\uffff\1\64\1\uffff\1\64\1\uffff\1\64\3\uffff\1\u01d5\4\64\1\u01da\1\64\1\uffff\1\64\1\u01dd\2\64\1\uffff\1\64\1\u01e1\1\uffff\1\64\1\u01e3\1\64\1\uffff\1\64\1\uffff\1\u01e6\1\64\1\uffff\2\64\1\u01ea\1\uffff";
     static final String DFA12_eofS =
-        "\u0200\uffff";
+        "\u01eb\uffff";
     static final String DFA12_minS =
-        "\1\0\1\120\1\151\1\145\1\160\2\145\2\154\1\143\1\141\1\146\1\145\1\156\1\163\1\165\1\156\2\141\1\145\1\122\1\141\1\156\1\157\1\141\1\150\1\145\2\141\2\75\1\145\2\75\2\105\5\uffff\1\55\2\uffff\2\0\1\52\2\uffff\1\115\1\163\1\157\1\uffff\1\164\1\163\1\160\1\165\1\155\1\55\1\171\1\156\1\154\1\142\1\160\1\144\1\145\1\157\1\141\1\162\1\161\1\162\1\160\1\55\1\141\1\164\1\144\1\164\1\145\1\164\1\144\1\142\1\156\1\163\1\154\1\164\1\105\1\151\1\163\1\164\1\157\1\154\1\141\1\154\1\155\1\145\1\163\1\143\1\156\1\162\3\uffff\1\154\4\uffff\1\114\1\104\12\uffff\1\116\1\151\1\154\1\150\1\164\1\151\1\145\1\156\1\uffff\2\55\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\1\165\1\144\1\55\1\165\1\uffff\1\162\1\55\1\105\1\145\1\162\1\160\1\55\1\145\2\165\2\145\1\105\1\160\1\157\1\163\1\145\1\160\1\154\1\55\1\147\1\163\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\114\1\55\1\104\1\156\1\145\1\55\1\160\1\143\2\55\2\uffff\1\147\1\144\1\162\1\145\1\55\1\145\1\55\1\164\1\156\1\160\1\151\1\145\1\143\1\uffff\2\164\1\145\1\uffff\1\166\1\162\1\124\1\165\1\uffff\1\154\1\141\1\154\1\55\1\167\1\116\1\157\1\162\1\145\1\147\1\55\1\157\1\uffff\1\55\1\145\1\154\1\153\1\55\1\163\2\141\1\147\1\117\1\uffff\1\151\1\145\1\141\1\165\1\uffff\1\141\1\55\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\157\2\126\1\162\1\145\1\156\1\141\1\164\1\55\1\154\1\164\1\uffff\1\141\1\55\1\163\1\151\1\144\1\145\1\uffff\1\167\1\uffff\1\55\1\145\1\55\1\uffff\1\55\1\154\1\142\1\141\1\127\1\141\1\163\1\156\1\164\1\143\1\uffff\1\164\1\145\1\141\1\163\1\164\1\145\1\166\1\55\1\124\1\145\1\143\1\144\1\55\2\141\2\55\1\156\1\141\1\163\1\126\1\uffff\1\124\1\126\1\171\1\uffff\1\141\1\164\1\55\1\162\1\163\1\uffff\1\170\2\uffff\1\55\1\154\1\164\1\55\1\147\1\163\2\55\1\153\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\2\145\1\uffff\2\162\2\uffff\1\164\1\154\1\153\3\141\1\55\1\154\1\171\1\uffff\2\55\1\151\1\uffff\2\145\1\uffff\1\162\1\122\2\uffff\1\141\3\55\1\157\1\55\1\145\1\156\1\163\1\141\1\106\1\144\2\151\1\55\1\123\1\55\1\162\1\163\1\162\1\uffff\1\163\1\55\2\uffff\1\164\1\163\1\115\1\141\1\165\1\147\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\55\2\141\1\uffff\1\157\1\145\1\uffff\1\151\1\153\1\151\1\55\1\uffff\1\171\1\55\1\157\1\155\1\154\1\145\1\55\1\164\2\55\1\153\1\157\1\uffff\2\142\1\160\1\162\1\141\1\55\1\141\1\uffff\1\55\1\uffff\1\143\1\55\1\145\1\55\1\uffff\1\55\2\uffff\1\55\1\167\2\154\1\151\1\166\1\142\1\uffff\1\142\1\uffff\1\153\1\uffff\1\124\3\uffff\1\55\2\145\1\143\1\151\2\154\1\55\1\141\1\uffff\2\163\1\55\1\143\2\145\1\uffff\1\163\2\55\1\uffff\1\145\1\163\1\55\1\153\2\uffff\1\115\1\55\1\uffff\1\55\1\157\2\uffff\1\143\1\153\1\55\1\uffff";
+        "\1\0\1\120\1\151\1\145\1\160\2\145\2\154\1\143\1\146\1\156\1\163\1\156\3\141\1\145\1\122\1\141\1\156\1\157\1\145\1\141\1\150\1\145\2\141\2\75\1\145\2\75\1\117\2\105\5\uffff\1\55\2\uffff\2\0\1\52\2\uffff\1\115\1\163\1\157\1\uffff\1\164\1\163\1\160\1\165\1\155\1\55\1\171\1\156\1\154\1\142\1\160\1\144\1\145\1\157\1\141\1\162\1\161\1\160\1\55\1\144\1\164\1\145\1\144\1\142\1\156\1\162\1\163\1\154\1\164\1\105\1\151\1\163\1\164\1\157\1\141\1\164\1\154\1\141\1\154\1\155\1\145\1\163\1\143\1\156\1\162\3\uffff\1\154\4\uffff\1\116\1\114\1\104\12\uffff\1\116\1\151\1\154\1\150\1\164\1\151\1\145\1\156\1\uffff\2\55\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\2\165\1\uffff\1\105\1\145\1\162\1\55\1\145\1\165\1\144\1\55\1\165\2\145\1\105\1\160\1\157\1\163\1\145\1\160\1\162\1\55\1\154\1\55\1\147\1\163\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\105\1\114\1\55\1\104\1\156\1\145\1\55\1\160\1\143\2\55\2\uffff\1\147\1\144\1\162\1\145\1\55\1\145\1\55\1\164\1\156\1\160\1\151\1\145\1\164\1\166\1\162\1\124\1\uffff\1\154\1\141\1\143\1\uffff\1\154\1\55\1\167\1\116\1\157\1\162\1\145\1\147\1\55\1\164\1\145\1\uffff\1\157\1\uffff\1\55\1\145\1\154\1\153\1\55\1\163\2\141\1\147\1\55\1\117\1\uffff\1\151\1\145\1\141\1\165\1\uffff\1\141\1\55\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\126\1\145\1\156\1\141\1\55\1\154\1\157\1\164\1\uffff\1\141\1\55\1\163\1\151\1\144\1\145\1\uffff\1\163\1\162\1\167\1\uffff\1\55\1\145\1\55\1\uffff\1\55\1\154\1\142\1\141\1\uffff\1\127\1\141\1\163\1\156\1\164\1\143\1\uffff\1\164\1\145\1\141\1\163\1\164\1\145\1\166\1\55\1\124\1\145\1\143\1\141\1\55\1\156\1\141\1\163\1\uffff\1\124\1\144\1\126\1\171\1\uffff\1\141\1\164\1\55\1\162\2\55\1\163\1\uffff\1\170\2\uffff\1\55\1\154\1\164\1\55\1\147\1\163\2\55\1\153\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\1\145\1\162\1\uffff\1\164\1\154\1\153\1\141\1\145\1\141\1\55\1\154\1\171\1\uffff\1\55\2\uffff\1\55\1\151\1\uffff\2\145\1\uffff\1\162\1\122\2\uffff\1\141\3\55\1\157\1\55\1\145\1\156\1\163\1\141\1\106\1\151\1\55\1\123\1\55\1\163\1\144\1\162\1\uffff\1\163\1\55\2\uffff\1\164\1\163\1\115\1\141\1\165\1\147\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\141\1\uffff\1\157\1\145\1\uffff\1\153\1\55\1\151\1\55\1\uffff\1\171\1\55\1\157\1\155\1\154\1\145\1\55\1\164\2\55\1\153\1\157\1\142\1\160\1\162\1\55\1\uffff\1\141\1\uffff\1\55\1\uffff\1\143\1\55\1\145\1\55\1\uffff\1\55\2\uffff\1\55\1\167\1\154\1\151\1\166\1\uffff\1\142\1\uffff\1\153\1\uffff\1\124\3\uffff\1\55\1\145\1\143\1\151\1\154\1\55\1\141\1\uffff\1\163\1\55\1\143\1\145\1\uffff\1\163\1\55\1\uffff\1\145\1\55\1\153\1\uffff\1\115\1\uffff\1\55\1\157\1\uffff\1\143\1\153\1\55\1\uffff";
     static final String DFA12_maxS =
-        "\1\uffff\1\165\1\151\1\162\1\171\1\145\1\155\1\170\1\154\1\164\1\141\1\156\1\164\1\170\1\163\1\165\1\156\2\141\1\165\1\141\1\162\1\156\3\157\1\145\1\157\1\141\2\75\1\145\2\75\2\105\5\uffff\1\172\2\uffff\2\uffff\1\57\2\uffff\1\115\1\163\1\157\1\uffff\1\164\1\163\1\160\1\165\1\155\1\172\1\171\1\156\1\154\1\142\1\164\1\144\1\145\1\157\3\162\1\163\1\160\1\172\1\141\1\164\1\144\1\164\1\145\1\164\1\144\1\142\1\156\1\163\1\154\1\164\1\105\1\157\1\163\1\164\1\157\1\162\1\141\1\154\1\155\1\145\1\163\1\143\1\156\1\162\3\uffff\1\154\4\uffff\1\114\1\104\12\uffff\1\116\1\151\1\154\1\150\1\164\1\151\1\145\1\156\1\uffff\2\172\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\1\165\1\144\1\172\1\165\1\uffff\1\162\1\172\1\105\1\145\1\162\1\160\1\172\1\145\2\165\2\145\1\105\1\160\1\157\1\163\1\145\1\160\1\154\1\172\1\147\1\163\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\114\1\172\1\104\1\156\1\145\1\172\1\160\1\143\2\172\2\uffff\1\147\1\144\1\162\1\145\1\172\1\145\1\172\1\164\1\156\1\160\1\151\1\145\1\143\1\uffff\2\164\1\145\1\uffff\1\166\1\162\1\124\1\165\1\uffff\1\154\1\141\1\154\1\172\1\167\1\116\1\157\1\162\1\145\1\147\1\172\1\157\1\uffff\1\172\1\145\1\154\1\153\1\172\1\163\2\141\1\147\1\117\1\uffff\1\151\1\145\1\141\1\165\1\uffff\1\141\1\172\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\157\2\163\1\162\1\145\1\156\1\141\1\164\1\172\1\154\1\164\1\uffff\1\141\1\172\1\163\1\151\1\144\1\145\1\uffff\1\167\1\uffff\1\172\1\145\1\172\1\uffff\1\172\1\154\1\142\1\141\1\127\1\141\1\163\1\156\1\164\1\143\1\uffff\1\164\1\145\1\141\1\163\1\164\1\145\1\166\1\172\1\124\1\145\1\143\1\144\1\172\2\141\2\172\1\156\1\141\1\163\1\126\1\uffff\1\124\1\126\1\171\1\uffff\1\141\1\164\1\172\1\162\1\163\1\uffff\1\170\2\uffff\1\172\1\154\1\164\1\172\1\147\1\163\2\172\1\153\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\2\145\1\uffff\2\162\2\uffff\1\164\1\154\1\153\3\141\1\172\1\154\1\171\1\uffff\2\172\1\151\1\uffff\2\145\1\uffff\1\162\1\122\2\uffff\1\141\3\172\1\157\1\172\1\145\1\156\1\163\1\141\1\106\1\144\2\151\1\172\1\124\1\172\1\162\1\163\1\162\1\uffff\1\163\1\172\2\uffff\1\164\1\163\1\115\1\141\1\165\1\147\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\172\2\141\1\uffff\1\157\1\145\1\uffff\1\151\1\153\1\151\1\172\1\uffff\1\171\1\172\1\157\1\155\1\154\1\145\1\172\1\164\2\172\1\153\1\157\1\uffff\2\142\1\160\1\162\1\141\1\172\1\141\1\uffff\1\172\1\uffff\1\143\1\172\1\145\1\172\1\uffff\1\172\2\uffff\1\172\1\167\2\154\1\151\1\166\1\142\1\uffff\1\142\1\uffff\1\153\1\uffff\1\124\3\uffff\1\172\2\145\1\143\1\151\2\154\1\172\1\141\1\uffff\2\163\1\172\1\143\2\145\1\uffff\1\163\2\172\1\uffff\1\145\1\163\1\172\1\153\2\uffff\1\115\1\172\1\uffff\1\172\1\157\2\uffff\1\143\1\153\1\172\1\uffff";
+        "\1\uffff\1\165\1\151\1\162\1\171\1\145\1\155\1\170\1\154\1\164\1\156\1\170\1\163\1\156\3\141\1\165\1\141\1\162\1\156\1\157\1\164\2\157\1\145\1\157\1\141\2\75\1\145\2\75\1\117\2\105\5\uffff\1\172\2\uffff\2\uffff\1\57\2\uffff\1\115\1\163\1\157\1\uffff\1\164\1\163\1\160\1\165\1\155\1\172\1\171\1\156\1\154\1\142\1\164\1\144\1\145\1\157\3\162\1\160\1\172\1\144\1\164\1\145\1\144\1\142\1\156\2\163\1\154\1\164\1\105\1\157\1\163\1\164\1\157\1\141\1\164\1\162\1\141\1\154\1\155\1\145\1\163\1\143\1\156\1\162\3\uffff\1\154\4\uffff\1\116\1\114\1\104\12\uffff\1\116\1\151\1\154\1\150\1\164\1\151\1\145\1\156\1\uffff\2\172\3\145\1\162\1\163\1\155\1\167\1\162\2\151\1\166\2\165\1\uffff\1\105\1\145\1\162\1\172\1\145\1\165\1\144\1\172\1\165\2\145\1\105\1\160\1\157\1\163\1\145\1\160\1\162\1\172\1\154\1\172\1\147\1\163\1\160\1\143\1\164\1\153\1\165\1\151\1\145\1\105\1\114\1\172\1\104\1\156\1\145\1\172\1\160\1\143\2\172\2\uffff\1\147\1\144\1\162\1\145\1\172\1\145\1\172\1\164\1\156\1\160\1\151\1\145\1\164\1\166\1\162\1\124\1\uffff\1\154\1\141\1\143\1\uffff\1\154\1\172\1\167\1\116\1\157\1\162\1\145\1\147\1\172\1\164\1\145\1\uffff\1\157\1\uffff\1\172\1\145\1\154\1\153\1\172\1\163\2\141\1\147\1\172\1\117\1\uffff\1\151\1\145\1\141\1\165\1\uffff\1\141\1\172\2\uffff\1\141\1\144\1\156\1\163\1\uffff\1\156\1\154\1\uffff\1\105\1\147\1\164\1\143\1\156\1\163\1\145\1\156\1\141\1\172\1\154\1\157\1\164\1\uffff\1\141\1\172\1\163\1\151\1\144\1\145\1\uffff\1\163\1\162\1\167\1\uffff\1\172\1\145\1\172\1\uffff\1\172\1\154\1\142\1\141\1\uffff\1\127\1\141\1\163\1\156\1\164\1\143\1\uffff\1\164\1\145\1\141\1\163\1\164\1\145\1\166\1\172\1\124\1\145\1\143\1\141\1\172\1\156\1\141\1\163\1\uffff\1\124\1\144\1\126\1\171\1\uffff\1\141\1\164\1\172\1\162\2\172\1\163\1\uffff\1\170\2\uffff\1\172\1\154\1\164\1\172\1\147\1\163\2\172\1\153\1\145\1\144\1\154\1\151\1\163\1\155\1\145\1\uffff\1\141\1\124\1\145\1\162\1\uffff\1\164\1\154\1\153\1\141\1\145\1\141\1\172\1\154\1\171\1\uffff\1\172\2\uffff\1\172\1\151\1\uffff\2\145\1\uffff\1\162\1\122\2\uffff\1\141\3\172\1\157\1\172\1\145\1\156\1\163\1\141\1\106\1\151\1\172\1\124\1\172\1\163\1\144\1\162\1\uffff\1\163\1\172\2\uffff\1\164\1\163\1\115\1\141\1\165\1\147\3\uffff\1\156\1\uffff\1\156\1\164\1\153\1\163\1\154\1\141\1\uffff\1\157\1\145\1\uffff\1\153\1\172\1\151\1\172\1\uffff\1\171\1\172\1\157\1\155\1\154\1\145\1\172\1\164\2\172\1\153\1\157\1\142\1\160\1\162\1\172\1\uffff\1\141\1\uffff\1\172\1\uffff\1\143\1\172\1\145\1\172\1\uffff\1\172\2\uffff\1\172\1\167\1\154\1\151\1\166\1\uffff\1\142\1\uffff\1\153\1\uffff\1\124\3\uffff\1\172\1\145\1\143\1\151\1\154\1\172\1\141\1\uffff\1\163\1\172\1\143\1\145\1\uffff\1\163\1\172\1\uffff\1\145\1\172\1\153\1\uffff\1\115\1\uffff\1\172\1\157\1\uffff\1\143\1\153\1\172\1\uffff";
     static final String DFA12_acceptS =
-        "\44\uffff\1\110\1\111\1\112\1\113\1\114\1\uffff\1\115\1\116\3\uffff\1\122\1\123\3\uffff\1\115\56\uffff\1\65\1\64\1\66\1\uffff\1\103\1\101\1\104\1\102\2\uffff\1\110\1\111\1\112\1\113\1\114\1\116\1\117\1\120\1\121\1\122\10\uffff\1\45\21\uffff\1\73\47\uffff\1\5\1\6\15\uffff\1\47\3\uffff\1\74\4\uffff\1\21\14\uffff\1\53\12\uffff\1\107\4\uffff\1\2\2\uffff\1\77\1\4\4\uffff\1\46\2\uffff\1\52\20\uffff\1\72\6\uffff\1\42\1\uffff\1\54\3\uffff\1\57\12\uffff\1\70\25\uffff\1\22\3\uffff\1\105\5\uffff\1\100\1\uffff\1\63\1\61\20\uffff\1\36\4\uffff\1\13\2\uffff\1\43\1\76\11\uffff\1\51\3\uffff\1\75\2\uffff\1\106\2\uffff\1\41\1\56\24\uffff\1\32\2\uffff\1\40\1\44\6\uffff\1\26\1\7\1\27\1\uffff\1\55\10\uffff\1\15\2\uffff\1\16\4\uffff\1\60\14\uffff\1\12\7\uffff\1\37\1\uffff\1\62\4\uffff\1\34\1\uffff\1\11\1\24\7\uffff\1\23\1\uffff\1\50\1\uffff\1\1\1\uffff\1\3\1\10\1\25\11\uffff\1\33\6\uffff\1\71\3\uffff\1\35\4\uffff\1\17\1\14\2\uffff\1\31\2\uffff\1\20\1\30\3\uffff\1\67";
+        "\44\uffff\1\107\1\110\1\111\1\112\1\113\1\uffff\1\114\1\115\3\uffff\1\121\1\122\3\uffff\1\114\55\uffff\1\63\1\62\1\64\1\uffff\1\101\1\77\1\102\1\100\3\uffff\1\107\1\110\1\111\1\112\1\113\1\115\1\116\1\117\1\120\1\121\10\uffff\1\43\17\uffff\1\71\51\uffff\1\5\1\6\20\uffff\1\15\3\uffff\1\45\13\uffff\1\72\1\uffff\1\51\13\uffff\1\106\4\uffff\1\2\2\uffff\1\75\1\4\4\uffff\1\44\2\uffff\1\50\15\uffff\1\70\6\uffff\1\40\3\uffff\1\52\3\uffff\1\55\4\uffff\1\103\6\uffff\1\66\20\uffff\1\16\4\uffff\1\104\7\uffff\1\76\1\uffff\1\61\1\57\20\uffff\1\34\4\uffff\1\25\11\uffff\1\47\1\uffff\1\41\1\74\2\uffff\1\73\2\uffff\1\105\2\uffff\1\37\1\54\22\uffff\1\30\2\uffff\1\36\1\42\6\uffff\1\22\1\7\1\23\1\uffff\1\53\6\uffff\1\13\2\uffff\1\14\4\uffff\1\56\20\uffff\1\24\1\uffff\1\35\1\uffff\1\60\4\uffff\1\32\1\uffff\1\11\1\20\5\uffff\1\17\1\uffff\1\46\1\uffff\1\1\1\uffff\1\3\1\10\1\21\7\uffff\1\31\4\uffff\1\67\2\uffff\1\33\3\uffff\1\12\1\uffff\1\27\2\uffff\1\26\3\uffff\1\65";
     static final String DFA12_specialS =
-        "\1\1\53\uffff\1\2\1\0\u01d2\uffff}>";
+        "\1\0\53\uffff\1\1\1\2\u01bd\uffff}>";
     static final String[] DFA12_transitionS = {
-            "\11\60\2\57\2\60\1\57\22\60\1\57\1\36\1\54\4\60\1\55\4\60\1\47\1\52\1\60\1\56\12\53\1\46\1\50\1\40\1\35\1\41\2\60\1\52\1\1\1\52\1\37\1\15\1\10\1\24\1\52\1\26\2\52\1\27\1\22\4\52\1\43\1\11\1\32\1\16\3\52\1\42\1\52\1\44\1\60\1\45\1\51\1\52\1\60\1\20\1\4\1\31\1\6\1\7\1\30\1\52\1\12\1\13\1\52\1\5\1\21\1\33\1\52\1\17\1\25\1\52\1\23\1\14\1\3\1\52\1\34\1\2\3\52\uff85\60",
+            "\11\60\2\57\2\60\1\57\22\60\1\57\1\35\1\54\4\60\1\55\4\60\1\47\1\52\1\60\1\56\12\53\1\46\1\50\1\37\1\34\1\40\2\60\1\52\1\1\1\52\1\36\1\13\1\10\1\22\1\52\1\24\2\52\1\25\1\17\1\41\3\52\1\43\1\11\1\31\1\14\3\52\1\42\1\52\1\44\1\60\1\45\1\51\1\52\1\60\1\15\1\4\1\30\1\6\1\7\1\27\1\52\1\20\1\12\1\52\1\5\1\16\1\32\2\52\1\23\1\52\1\21\1\26\1\3\1\52\1\33\1\2\3\52\uff85\60",
             "\1\61\36\uffff\1\63\5\uffff\1\62",
             "\1\65",
             "\1\66\11\uffff\1\67\2\uffff\1\70",
@@ -2812,30 +2783,30 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\101\1\76\1\100\11\uffff\1\77",
             "\1\102",
             "\1\104\1\uffff\1\105\16\uffff\1\103",
-            "\1\106",
-            "\1\110\7\uffff\1\107",
-            "\1\112\16\uffff\1\111",
-            "\1\113\11\uffff\1\114",
+            "\1\107\7\uffff\1\106",
+            "\1\110\11\uffff\1\111",
+            "\1\112",
+            "\1\113",
+            "\1\114",
             "\1\115",
             "\1\116",
-            "\1\117",
-            "\1\120",
-            "\1\121",
-            "\1\122\17\uffff\1\123",
-            "\1\125\16\uffff\1\124",
-            "\1\127\20\uffff\1\126",
-            "\1\130",
-            "\1\131",
-            "\1\134\12\uffff\1\133\2\uffff\1\132",
-            "\1\136\6\uffff\1\135",
-            "\1\137",
-            "\1\141\15\uffff\1\140",
+            "\1\117\17\uffff\1\120",
+            "\1\122\16\uffff\1\121",
+            "\1\124\20\uffff\1\123",
+            "\1\125",
+            "\1\126",
+            "\1\130\16\uffff\1\127",
+            "\1\133\12\uffff\1\132\2\uffff\1\131",
+            "\1\135\6\uffff\1\134",
+            "\1\136",
+            "\1\140\15\uffff\1\137",
+            "\1\141",
             "\1\142",
-            "\1\143",
+            "\1\144",
             "\1\145",
             "\1\146",
-            "\1\147",
-            "\1\151",
+            "\1\150",
+            "\1\152",
             "\1\153",
             "\1\154",
             "",
@@ -2872,27 +2843,27 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0089\20\uffff\1\u008a",
             "\1\u008b",
             "\1\u008d\1\u008c",
-            "\1\u008e\1\u008f",
-            "\1\u0090",
+            "\1\u008e",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0090",
+            "\1\u0091",
             "\1\u0092",
             "\1\u0093",
             "\1\u0094",
             "\1\u0095",
-            "\1\u0096",
-            "\1\u0097",
+            "\1\u0096\1\u0097",
             "\1\u0098",
             "\1\u0099",
             "\1\u009a",
             "\1\u009b",
-            "\1\u009c",
-            "\1\u009d",
+            "\1\u009d\5\uffff\1\u009c",
             "\1\u009e",
-            "\1\u00a0\5\uffff\1\u009f",
+            "\1\u009f",
+            "\1\u00a0",
             "\1\u00a1",
             "\1\u00a2",
-            "\1\u00a3",
-            "\1\u00a4\5\uffff\1\u00a5",
+            "\1\u00a3\5\uffff\1\u00a4",
+            "\1\u00a5",
             "\1\u00a6",
             "\1\u00a7",
             "\1\u00a8",
@@ -2900,15 +2871,15 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00aa",
             "\1\u00ab",
             "\1\u00ac",
-            "\1\u00ad",
             "",
             "",
             "",
-            "\1\u00ae",
+            "\1\u00ad",
             "",
             "",
             "",
             "",
+            "\1\u00ae",
             "\1\u00af",
             "\1\u00b0",
             "",
@@ -2945,16 +2916,17 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00c5",
             "\1\u00c6",
             "\1\u00c7",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u00c9",
             "",
+            "\1\u00c8",
+            "\1\u00c9",
             "\1\u00ca",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\23\64\1\u00cb\6\64",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u00cc",
             "\1\u00cd",
             "\1\u00ce",
-            "\1\u00cf",
-            "\1\u00d0",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u00d0",
+            "\1\u00d1",
             "\1\u00d2",
             "\1\u00d3",
             "\1\u00d4",
@@ -2963,11 +2935,10 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00d7",
             "\1\u00d8",
             "\1\u00d9",
-            "\1\u00da",
-            "\1\u00db",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\23\64\1\u00da\6\64",
             "\1\u00dc",
-            "\1\u00dd",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u00de",
             "\1\u00df",
             "\1\u00e0",
             "\1\u00e1",
@@ -3002,7 +2973,6 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u00fe",
             "\1\u00ff",
             "\1\u0100",
-            "",
             "\1\u0101",
             "\1\u0102",
             "\1\u0103",
@@ -3010,30 +2980,31 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u0104",
             "\1\u0105",
             "\1\u0106",
-            "\1\u0107",
             "",
-            "\1\u0108",
+            "\1\u0107",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0109",
             "\1\u010a",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u010b",
             "\1\u010c",
             "\1\u010d",
             "\1\u010e",
-            "\1\u010f",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0110",
             "\1\u0111",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u0113",
+            "",
+            "\1\u0112",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0114",
             "\1\u0115",
             "\1\u0116",
-            "\1\u0117",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0118",
             "\1\u0119",
             "\1\u011a",
             "\1\u011b",
-            "\1\u011c",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u011d",
             "",
             "\1\u011e",
@@ -3058,89 +3029,92 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u012c",
             "\1\u012d",
             "\1\u012e",
-            "\1\u012f",
-            "\1\u0131\34\uffff\1\u0130",
-            "\1\u0132\34\uffff\1\u0133",
-            "\1\u0134",
+            "\1\u012f\34\uffff\1\u0130",
+            "\1\u0131",
+            "\1\u0132",
+            "\1\u0133",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0135",
             "\1\u0136",
             "\1\u0137",
+            "",
             "\1\u0138",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u013a",
             "\1\u013b",
-            "",
             "\1\u013c",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u013d",
+            "",
             "\1\u013e",
             "\1\u013f",
             "\1\u0140",
-            "\1\u0141",
-            "",
-            "\1\u0142",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u0144",
+            "\1\u0142",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0145",
+            "\1\u0146",
             "\1\u0147",
+            "",
             "\1\u0148",
             "\1\u0149",
             "\1\u014a",
             "\1\u014b",
             "\1\u014c",
             "\1\u014d",
+            "",
             "\1\u014e",
             "\1\u014f",
-            "",
             "\1\u0150",
             "\1\u0151",
             "\1\u0152",
             "\1\u0153",
             "\1\u0154",
-            "\1\u0155",
-            "\1\u0156",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0156",
+            "\1\u0157",
             "\1\u0158",
             "\1\u0159",
-            "\1\u015a",
-            "\1\u015b",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u015b",
+            "\1\u015c",
             "\1\u015d",
+            "",
             "\1\u015e",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u015f",
+            "\1\u0160",
             "\1\u0161",
+            "",
             "\1\u0162",
             "\1\u0163",
-            "\1\u0164",
-            "",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0165",
-            "\1\u0166",
-            "\1\u0167",
-            "",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0168",
+            "",
             "\1\u0169",
+            "",
+            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u016b",
             "\1\u016c",
-            "",
-            "\1\u016d",
-            "",
-            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u016e",
             "\1\u016f",
-            "\1\u0170",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0172",
             "\1\u0173",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0174",
+            "\1\u0175",
             "\1\u0176",
             "\1\u0177",
             "\1\u0178",
             "\1\u0179",
+            "",
             "\1\u017a",
             "\1\u017b",
             "\1\u017c",
@@ -3150,168 +3124,144 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             "\1\u017f",
             "\1\u0180",
             "\1\u0181",
-            "",
             "\1\u0182",
             "\1\u0183",
-            "",
-            "",
-            "\1\u0184",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u0185",
             "\1\u0186",
-            "\1\u0187",
-            "\1\u0188",
-            "\1\u0189",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u018b",
-            "\1\u018c",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
+            "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u018f",
+            "\1\u0189",
             "",
-            "\1\u0190",
-            "\1\u0191",
+            "\1\u018a",
+            "\1\u018b",
             "",
-            "\1\u0192",
-            "\1\u0193",
+            "\1\u018c",
+            "\1\u018d",
             "",
             "",
-            "\1\u0194",
+            "\1\u018e",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0192",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u0194",
+            "\1\u0195",
+            "\1\u0196",
+            "\1\u0197",
             "\1\u0198",
+            "\1\u0199",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u019c\1\u019b",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u019a",
-            "\1\u019b",
-            "\1\u019c",
-            "\1\u019d",
             "\1\u019e",
             "\1\u019f",
             "\1\u01a0",
+            "",
             "\1\u01a1",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01a4\1\u01a3",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
+            "",
+            "\1\u01a3",
+            "\1\u01a4",
+            "\1\u01a5",
             "\1\u01a6",
             "\1\u01a7",
             "\1\u01a8",
             "",
-            "\1\u01a9",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "",
+            "\1\u01a9",
+            "",
+            "\1\u01aa",
             "\1\u01ab",
             "\1\u01ac",
             "\1\u01ad",
             "\1\u01ae",
             "\1\u01af",
-            "\1\u01b0",
-            "",
-            "",
             "",
+            "\1\u01b0",
             "\1\u01b1",
             "",
             "\1\u01b2",
-            "\1\u01b3",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01b4",
-            "\1\u01b5",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "",
             "\1\u01b6",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01b8",
             "\1\u01b9",
-            "",
             "\1\u01ba",
             "\1\u01bb",
-            "",
-            "\1\u01bc",
+            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "\1\u01bd",
-            "\1\u01be",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "",
-            "\1\u01c0",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01c0",
+            "\1\u01c1",
             "\1\u01c2",
             "\1\u01c3",
             "\1\u01c4",
-            "\1\u01c5",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01c7",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01ca",
-            "\1\u01cb",
             "",
-            "\1\u01cc",
-            "\1\u01cd",
-            "\1\u01ce",
-            "\1\u01cf",
-            "\1\u01d0",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01d2",
+            "\1\u01c6",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
-            "\1\u01d4",
+            "\1\u01c8",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01d6",
+            "\1\u01ca",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01da",
-            "\1\u01db",
-            "\1\u01dc",
-            "\1\u01dd",
-            "\1\u01de",
-            "\1\u01df",
+            "\1\u01ce",
+            "\1\u01cf",
+            "\1\u01d0",
+            "\1\u01d1",
             "",
-            "\1\u01e0",
+            "\1\u01d2",
             "",
-            "\1\u01e1",
+            "\1\u01d3",
             "",
-            "\1\u01e2",
+            "\1\u01d4",
             "",
             "",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01e4",
-            "\1\u01e5",
-            "\1\u01e6",
-            "\1\u01e7",
-            "\1\u01e8",
-            "\1\u01e9",
+            "\1\u01d6",
+            "\1\u01d7",
+            "\1\u01d8",
+            "\1\u01d9",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01eb",
+            "\1\u01db",
             "",
-            "\1\u01ec",
-            "\1\u01ed",
+            "\1\u01dc",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01ef",
-            "\1\u01f0",
-            "\1\u01f1",
+            "\1\u01de",
+            "\1\u01df",
             "",
-            "\1\u01f2",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01e0",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             "",
-            "\1\u01f5",
-            "\1\u01f6",
+            "\1\u01e2",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01f8",
-            "",
+            "\1\u01e4",
             "",
-            "\1\u01f9",
-            "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
+            "\1\u01e5",
             "",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
-            "\1\u01fc",
-            "",
+            "\1\u01e7",
             "",
-            "\1\u01fd",
-            "\1\u01fe",
+            "\1\u01e8",
+            "\1\u01e9",
             "\1\64\2\uffff\12\64\7\uffff\32\64\4\uffff\1\64\1\uffff\32\64",
             ""
     };
@@ -3346,23 +3296,13 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
             this.transition = DFA12_transition;
         }
         public String getDescription() {
-            return "1:1: Tokens : ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | T__86 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER );";
+            return "1:1: Tokens : ( T__16 | T__17 | T__18 | T__19 | T__20 | T__21 | T__22 | T__23 | T__24 | T__25 | T__26 | T__27 | T__28 | T__29 | T__30 | T__31 | T__32 | T__33 | T__34 | T__35 | T__36 | T__37 | T__38 | T__39 | T__40 | T__41 | T__42 | T__43 | T__44 | T__45 | T__46 | T__47 | T__48 | T__49 | T__50 | T__51 | T__52 | T__53 | T__54 | T__55 | T__56 | T__57 | T__58 | T__59 | T__60 | T__61 | T__62 | T__63 | T__64 | T__65 | T__66 | T__67 | T__68 | T__69 | T__70 | T__71 | T__72 | T__73 | T__74 | T__75 | T__76 | T__77 | T__78 | T__79 | T__80 | T__81 | T__82 | T__83 | T__84 | T__85 | RULE_LIST_OPEN | RULE_LIST_CLOSED | RULE_ASSOCIATION | RULE_SEPARATOR | RULE_DECLARATION_FINISHED | RULE_ID | RULE_INT | RULE_STRING | RULE_ML_COMMENT | RULE_SL_COMMENT | RULE_WS | RULE_ANY_OTHER );";
         }
         public int specialStateTransition(int s, IntStream _input) throws NoViableAltException {
             IntStream input = _input;
         	int _s = s;
             switch ( s ) {
                     case 0 : 
-                        int LA12_45 = input.LA(1);
-
-                        s = -1;
-                        if ( ((LA12_45>='\u0000' && LA12_45<='\uFFFF')) ) {s = 115;}
-
-                        else s = 48;
-
-                        if ( s>=0 ) return s;
-                        break;
-                    case 1 : 
                         int LA12_0 = input.LA(1);
 
                         s = -1;
@@ -3384,53 +3324,53 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else if ( (LA12_0=='S') ) {s = 9;}
 
-                        else if ( (LA12_0=='h') ) {s = 10;}
+                        else if ( (LA12_0=='i') ) {s = 10;}
 
-                        else if ( (LA12_0=='i') ) {s = 11;}
+                        else if ( (LA12_0=='E') ) {s = 11;}
 
-                        else if ( (LA12_0=='s') ) {s = 12;}
+                        else if ( (LA12_0=='U') ) {s = 12;}
 
-                        else if ( (LA12_0=='E') ) {s = 13;}
+                        else if ( (LA12_0=='a') ) {s = 13;}
 
-                        else if ( (LA12_0=='U') ) {s = 14;}
+                        else if ( (LA12_0=='l') ) {s = 14;}
 
-                        else if ( (LA12_0=='o') ) {s = 15;}
+                        else if ( (LA12_0=='M') ) {s = 15;}
 
-                        else if ( (LA12_0=='a') ) {s = 16;}
+                        else if ( (LA12_0=='h') ) {s = 16;}
 
-                        else if ( (LA12_0=='l') ) {s = 17;}
+                        else if ( (LA12_0=='r') ) {s = 17;}
 
-                        else if ( (LA12_0=='M') ) {s = 18;}
+                        else if ( (LA12_0=='G') ) {s = 18;}
 
-                        else if ( (LA12_0=='r') ) {s = 19;}
+                        else if ( (LA12_0=='p') ) {s = 19;}
 
-                        else if ( (LA12_0=='G') ) {s = 20;}
+                        else if ( (LA12_0=='I') ) {s = 20;}
 
-                        else if ( (LA12_0=='p') ) {s = 21;}
+                        else if ( (LA12_0=='L') ) {s = 21;}
 
-                        else if ( (LA12_0=='I') ) {s = 22;}
+                        else if ( (LA12_0=='s') ) {s = 22;}
 
-                        else if ( (LA12_0=='L') ) {s = 23;}
+                        else if ( (LA12_0=='f') ) {s = 23;}
 
-                        else if ( (LA12_0=='f') ) {s = 24;}
+                        else if ( (LA12_0=='c') ) {s = 24;}
 
-                        else if ( (LA12_0=='c') ) {s = 25;}
+                        else if ( (LA12_0=='T') ) {s = 25;}
 
-                        else if ( (LA12_0=='T') ) {s = 26;}
+                        else if ( (LA12_0=='m') ) {s = 26;}
 
-                        else if ( (LA12_0=='m') ) {s = 27;}
+                        else if ( (LA12_0=='v') ) {s = 27;}
 
-                        else if ( (LA12_0=='v') ) {s = 28;}
+                        else if ( (LA12_0=='=') ) {s = 28;}
 
-                        else if ( (LA12_0=='=') ) {s = 29;}
+                        else if ( (LA12_0=='!') ) {s = 29;}
 
-                        else if ( (LA12_0=='!') ) {s = 30;}
+                        else if ( (LA12_0=='D') ) {s = 30;}
 
-                        else if ( (LA12_0=='D') ) {s = 31;}
+                        else if ( (LA12_0=='<') ) {s = 31;}
 
-                        else if ( (LA12_0=='<') ) {s = 32;}
+                        else if ( (LA12_0=='>') ) {s = 32;}
 
-                        else if ( (LA12_0=='>') ) {s = 33;}
+                        else if ( (LA12_0=='N') ) {s = 33;}
 
                         else if ( (LA12_0=='Y') ) {s = 34;}
 
@@ -3448,7 +3388,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else if ( (LA12_0=='^') ) {s = 41;}
 
-                        else if ( (LA12_0=='-'||LA12_0=='A'||LA12_0=='C'||LA12_0=='H'||(LA12_0>='J' && LA12_0<='K')||(LA12_0>='N' && LA12_0<='Q')||(LA12_0>='V' && LA12_0<='X')||LA12_0=='Z'||LA12_0=='_'||LA12_0=='g'||LA12_0=='j'||LA12_0=='n'||LA12_0=='q'||LA12_0=='u'||(LA12_0>='x' && LA12_0<='z')) ) {s = 42;}
+                        else if ( (LA12_0=='-'||LA12_0=='A'||LA12_0=='C'||LA12_0=='H'||(LA12_0>='J' && LA12_0<='K')||(LA12_0>='O' && LA12_0<='Q')||(LA12_0>='V' && LA12_0<='X')||LA12_0=='Z'||LA12_0=='_'||LA12_0=='g'||LA12_0=='j'||(LA12_0>='n' && LA12_0<='o')||LA12_0=='q'||LA12_0=='u'||(LA12_0>='x' && LA12_0<='z')) ) {s = 42;}
 
                         else if ( ((LA12_0>='0' && LA12_0<='9')) ) {s = 43;}
 
@@ -3464,7 +3404,7 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         if ( s>=0 ) return s;
                         break;
-                    case 2 : 
+                    case 1 : 
                         int LA12_44 = input.LA(1);
 
                         s = -1;
@@ -3472,6 +3412,16 @@ public class InternalTestgeneratorDSLLexer extends Lexer {
 
                         else s = 48;
 
+                        if ( s>=0 ) return s;
+                        break;
+                    case 2 : 
+                        int LA12_45 = input.LA(1);
+
+                        s = -1;
+                        if ( ((LA12_45>='\u0000' && LA12_45<='\uFFFF')) ) {s = 115;}
+
+                        else s = 48;
+
                         if ( s>=0 ) return s;
                         break;
             }
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLParser.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLParser.java
index 945ecff85a7a33ff1c02bf59b78e4df8fbe3c139..100699f5733ed03e440fde08e40da9e19ac99f7c 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLParser.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/parser/antlr/internal/InternalTestgeneratorDSLParser.java
@@ -22,7 +22,7 @@ import java.util.ArrayList;
 @SuppressWarnings("all")
 public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser {
     public static final String[] tokenNames = new String[] {
-        "<invalid>", "<EOR>", "<DOWN>", "<UP>", "RULE_ID", "RULE_STRING", "RULE_ASSOCIATION", "RULE_LIST_OPEN", "RULE_SEPARATOR", "RULE_LIST_CLOSED", "RULE_DECLARATION_FINISHED", "RULE_INT", "RULE_ML_COMMENT", "RULE_SL_COMMENT", "RULE_WS", "RULE_ANY_OTHER", "'BPMNDiagram'", "'with'", "'testpackage'", "'bpmn'", "'key'", "'dmn'", "'embedded'", "'FlowElement'", "'StartEvent'", "'hardcoded'", "'inputs'", "'startVariables'", "'EndEvent'", "'UserTask'", "'inputVariables'", "'outputVariables'", "'and'", "'label'", "'ManualTask'", "'ScriptTask'", "'ServiceTask'", "'delegate'", "'external'", "'BusinessRuleTask'", "'resultVariable'", "'Gateway'", "'SequenceFlow'", "'expression'", "'ExternalTopic'", "'String'", "'proposals'", "'Integer'", "'Boolean'", "'Loop'", "'starts'", "'follows'", "'by'", "'ends'", "'has'", "'complexity'", "'passed'", "'Flow'", "'for'", "'flag'", "'elements'", "'without'", "'Test'", "'priority'", "'mocks'", "'variables'", "'check'", "'='", "'=='", "'!='", "'ExternalServiceMock'", "'topic'", "'DelegateMock'", "'rule'", "'if'", "'set'", "'manual'", "'setter'", "'true'", "'false'", "'<'", "'>'", "'<='", "'>='", "'GREEN'", "'YELLOW'", "'RED'"
+        "<invalid>", "<EOR>", "<DOWN>", "<UP>", "RULE_ID", "RULE_STRING", "RULE_ASSOCIATION", "RULE_LIST_OPEN", "RULE_SEPARATOR", "RULE_LIST_CLOSED", "RULE_DECLARATION_FINISHED", "RULE_INT", "RULE_ML_COMMENT", "RULE_SL_COMMENT", "RULE_WS", "RULE_ANY_OTHER", "'BPMNDiagram'", "'with'", "'testpackage'", "'bpmn'", "'key'", "'dmn'", "'embedded'", "'FlowElement'", "'StartEvent'", "'inputVariables'", "'EndEvent'", "'UserTask'", "'and'", "'label'", "'ManualTask'", "'ScriptTask'", "'ServiceTask'", "'delegate'", "'external'", "'hardcoded'", "'inputs'", "'BusinessRuleTask'", "'resultVariable'", "'Gateway'", "'SequenceFlow'", "'expression'", "'ExternalTopic'", "'String'", "'proposals'", "'Integer'", "'Boolean'", "'Loop'", "'starts'", "'follows'", "'by'", "'ends'", "'has'", "'complexity'", "'passed'", "'Flow'", "'for'", "'flag'", "'elements'", "'without'", "'Test'", "'priority'", "'mocks'", "'variables'", "'check'", "'='", "'=='", "'!='", "'ExternalServiceMock'", "'topic'", "'DelegateMock'", "'rule'", "'if'", "'set'", "'manual'", "'setter'", "'true'", "'false'", "'<'", "'>'", "'<='", "'>='", "'NONE'", "'GREEN'", "'YELLOW'", "'RED'"
     };
     public static final int T__50=50;
     public static final int T__19=19;
@@ -106,7 +106,6 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
     public static final int T__41=41;
     public static final int T__85=85;
     public static final int T__42=42;
-    public static final int T__86=86;
     public static final int T__43=43;
 
     // delegates
@@ -205,7 +204,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                 int alt1=2;
                 int LA1_0 = input.LA(1);
 
-                if ( (LA1_0==16||LA1_0==23||(LA1_0>=44 && LA1_0<=45)||(LA1_0>=47 && LA1_0<=49)||LA1_0==57||LA1_0==62||LA1_0==70||LA1_0==72) ) {
+                if ( (LA1_0==16||LA1_0==23||(LA1_0>=42 && LA1_0<=43)||(LA1_0>=45 && LA1_0<=47)||LA1_0==55||LA1_0==60||LA1_0==68||LA1_0==70) ) {
                     alt1=1;
                 }
 
@@ -345,35 +344,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                 alt2=2;
                 }
                 break;
+            case 43:
             case 45:
-            case 47:
-            case 48:
+            case 46:
                 {
                 alt2=3;
                 }
                 break;
-            case 57:
+            case 55:
                 {
                 alt2=4;
                 }
                 break;
-            case 62:
+            case 60:
                 {
                 alt2=5;
                 }
                 break;
+            case 68:
             case 70:
-            case 72:
                 {
                 alt2=6;
                 }
                 break;
-            case 44:
+            case 42:
                 {
                 alt2=7;
                 }
                 break;
-            case 49:
+            case 47:
                 {
                 alt2=8;
                 }
@@ -1444,7 +1443,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStartFlowElement"
-    // InternalTestgeneratorDSL.g:582:1: ruleStartFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:582:1: ruleStartFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleStartFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -1454,36 +1453,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         Token otherlv_3=null;
         Token otherlv_4=null;
         Token otherlv_5=null;
-        Token otherlv_6=null;
-        Token this_ASSOCIATION_7=null;
-        Token this_LIST_OPEN_8=null;
-        Token this_SEPARATOR_10=null;
-        Token this_LIST_CLOSED_12=null;
-        Token otherlv_13=null;
-        Token otherlv_14=null;
-        Token this_ASSOCIATION_15=null;
-        Token this_LIST_OPEN_16=null;
-        Token this_SEPARATOR_18=null;
-        Token this_LIST_CLOSED_20=null;
-        Token this_DECLARATION_FINISHED_21=null;
-        EObject lv_hardcodedInputs_9_0 = null;
-
-        EObject lv_hardcodedInputs_11_0 = null;
-
-        EObject lv_startVariables_17_0 = null;
+        Token this_ASSOCIATION_6=null;
+        Token this_LIST_OPEN_7=null;
+        Token this_SEPARATOR_9=null;
+        Token this_LIST_CLOSED_11=null;
+        Token this_DECLARATION_FINISHED_12=null;
+        EObject lv_inputVariables_8_0 = null;
 
-        EObject lv_startVariables_19_0 = null;
+        EObject lv_inputVariables_10_0 = null;
 
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:588:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:589:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:588:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:589:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:589:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:590:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:589:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:590:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'StartEvent' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
@@ -1523,42 +1511,34 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_3, grammarAccess.getStartFlowElementAccess().getStartEventKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:620:3: (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )?
+            // InternalTestgeneratorDSL.g:620:3: (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )?
             int alt12=2;
             int LA12_0 = input.LA(1);
 
             if ( (LA12_0==17) ) {
-                int LA12_1 = input.LA(2);
-
-                if ( (LA12_1==25) ) {
-                    alt12=1;
-                }
+                alt12=1;
             }
             switch (alt12) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:621:4: otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:621:4: otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED
                     {
                     otherlv_4=(Token)match(input,17,FOLLOW_19); 
 
                     				newLeafNode(otherlv_4, grammarAccess.getStartFlowElementAccess().getWithKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,25,FOLLOW_20); 
-
-                    				newLeafNode(otherlv_5, grammarAccess.getStartFlowElementAccess().getHardcodedKeyword_4_1());
-                    			
-                    otherlv_6=(Token)match(input,26,FOLLOW_12); 
+                    otherlv_5=(Token)match(input,25,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_6, grammarAccess.getStartFlowElementAccess().getInputsKeyword_4_2());
+                    				newLeafNode(otherlv_5, grammarAccess.getStartFlowElementAccess().getInputVariablesKeyword_4_1());
                     			
-                    this_ASSOCIATION_7=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
 
-                    				newLeafNode(this_ASSOCIATION_7, grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3());
+                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    this_LIST_OPEN_8=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_LIST_OPEN_7=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
-                    				newLeafNode(this_LIST_OPEN_8, grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4());
+                    				newLeafNode(this_LIST_OPEN_7, grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3());
                     			
-                    // InternalTestgeneratorDSL.g:641:4: ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )?
+                    // InternalTestgeneratorDSL.g:637:4: ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )?
                     int alt11=2;
                     int LA11_0 = input.LA(1);
 
@@ -1567,19 +1547,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     switch (alt11) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:642:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
+                            // InternalTestgeneratorDSL.g:638:5: ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )*
                             {
-                            // InternalTestgeneratorDSL.g:642:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:643:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
+                            // InternalTestgeneratorDSL.g:638:5: ( (lv_inputVariables_8_0= ruleVariableReference ) )
+                            // InternalTestgeneratorDSL.g:639:6: (lv_inputVariables_8_0= ruleVariableReference )
                             {
-                            // InternalTestgeneratorDSL.g:643:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:644:7: lv_hardcodedInputs_9_0= ruleVariableDeclaration
+                            // InternalTestgeneratorDSL.g:639:6: (lv_inputVariables_8_0= ruleVariableReference )
+                            // InternalTestgeneratorDSL.g:640:7: lv_inputVariables_8_0= ruleVariableReference
                             {
 
-                            							newCompositeNode(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0());
+                            							newCompositeNode(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0());
                             						
                             pushFollow(FOLLOW_15);
-                            lv_hardcodedInputs_9_0=ruleVariableDeclaration();
+                            lv_inputVariables_8_0=ruleVariableReference();
 
                             state._fsp--;
 
@@ -1589,9 +1569,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             							}
                             							add(
                             								current,
-                            								"hardcodedInputs",
-                            								lv_hardcodedInputs_9_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
+                            								"inputVariables",
+                            								lv_inputVariables_8_0,
+                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
                             							afterParserOrEnumRuleCall();
                             						
 
@@ -1600,7 +1580,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                             }
 
-                            // InternalTestgeneratorDSL.g:661:5: (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
+                            // InternalTestgeneratorDSL.g:657:5: (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )*
                             loop10:
                             do {
                                 int alt10=2;
@@ -1613,167 +1593,23 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                                 switch (alt10) {
                             	case 1 :
-                            	    // InternalTestgeneratorDSL.g:662:6: this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    {
-                            	    this_SEPARATOR_10=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_10, grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:666:6: ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:667:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:667:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:668:8: lv_hardcodedInputs_11_0= ruleVariableDeclaration
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getStartFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_hardcodedInputs_11_0=ruleVariableDeclaration();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getStartFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"hardcodedInputs",
-                            	    									lv_hardcodedInputs_11_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop10;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_12=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_10); 
-
-                    				newLeafNode(this_LIST_CLOSED_12, grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:692:3: (otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )?
-            int alt15=2;
-            int LA15_0 = input.LA(1);
-
-            if ( (LA15_0==17) ) {
-                alt15=1;
-            }
-            switch (alt15) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:693:4: otherlv_13= 'with' otherlv_14= 'startVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED
-                    {
-                    otherlv_13=(Token)match(input,17,FOLLOW_22); 
-
-                    				newLeafNode(otherlv_13, grammarAccess.getStartFlowElementAccess().getWithKeyword_5_0());
-                    			
-                    otherlv_14=(Token)match(input,27,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_14, grammarAccess.getStartFlowElementAccess().getStartVariablesKeyword_5_1());
-                    			
-                    this_ASSOCIATION_15=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_15, grammarAccess.getStartFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
-                    			
-                    this_LIST_OPEN_16=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_16, grammarAccess.getStartFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3());
-                    			
-                    // InternalTestgeneratorDSL.g:709:4: ( ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )* )?
-                    int alt14=2;
-                    int LA14_0 = input.LA(1);
-
-                    if ( (LA14_0==RULE_ID) ) {
-                        alt14=1;
-                    }
-                    switch (alt14) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:710:5: ( (lv_startVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:710:5: ( (lv_startVariables_17_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:711:6: (lv_startVariables_17_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:711:6: (lv_startVariables_17_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:712:7: lv_startVariables_17_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_startVariables_17_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getStartFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"startVariables",
-                            								lv_startVariables_17_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:729:5: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) ) )*
-                            loop13:
-                            do {
-                                int alt13=2;
-                                int LA13_0 = input.LA(1);
-
-                                if ( (LA13_0==RULE_SEPARATOR) ) {
-                                    alt13=1;
-                                }
-
-
-                                switch (alt13) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:730:6: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_startVariables_19_0= ruleVariableReference ) )
+                            	    // InternalTestgeneratorDSL.g:658:6: this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) )
                             	    {
-                            	    this_SEPARATOR_18=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+                            	    this_SEPARATOR_9=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
-                            	    						newLeafNode(this_SEPARATOR_18, grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0());
+                            	    						newLeafNode(this_SEPARATOR_9, grammarAccess.getStartFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0());
                             	    					
-                            	    // InternalTestgeneratorDSL.g:734:6: ( (lv_startVariables_19_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:735:7: (lv_startVariables_19_0= ruleVariableReference )
+                            	    // InternalTestgeneratorDSL.g:662:6: ( (lv_inputVariables_10_0= ruleVariableReference ) )
+                            	    // InternalTestgeneratorDSL.g:663:7: (lv_inputVariables_10_0= ruleVariableReference )
                             	    {
-                            	    // InternalTestgeneratorDSL.g:735:7: (lv_startVariables_19_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:736:8: lv_startVariables_19_0= ruleVariableReference
+                            	    // InternalTestgeneratorDSL.g:663:7: (lv_inputVariables_10_0= ruleVariableReference )
+                            	    // InternalTestgeneratorDSL.g:664:8: lv_inputVariables_10_0= ruleVariableReference
                             	    {
 
-                            	    								newCompositeNode(grammarAccess.getStartFlowElementAccess().getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0());
+                            	    								newCompositeNode(grammarAccess.getStartFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0());
                             	    							
                             	    pushFollow(FOLLOW_15);
-                            	    lv_startVariables_19_0=ruleVariableReference();
+                            	    lv_inputVariables_10_0=ruleVariableReference();
 
                             	    state._fsp--;
 
@@ -1783,8 +1619,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    								}
                             	    								add(
                             	    									current,
-                            	    									"startVariables",
-                            	    									lv_startVariables_19_0,
+                            	    									"inputVariables",
+                            	    									lv_inputVariables_10_0,
                             	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
                             	    								afterParserOrEnumRuleCall();
                             	    							
@@ -1799,7 +1635,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    break;
 
                             	default :
-                            	    break loop13;
+                            	    break loop10;
                                 }
                             } while (true);
 
@@ -1809,9 +1645,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    this_LIST_CLOSED_20=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_17); 
+                    this_LIST_CLOSED_11=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_17); 
 
-                    				newLeafNode(this_LIST_CLOSED_20, grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5());
+                    				newLeafNode(this_LIST_CLOSED_11, grammarAccess.getStartFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5());
                     			
 
                     }
@@ -1819,9 +1655,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_DECLARATION_FINISHED_21=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+            this_DECLARATION_FINISHED_12=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-            			newLeafNode(this_DECLARATION_FINISHED_21, grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6());
+            			newLeafNode(this_DECLARATION_FINISHED_12, grammarAccess.getStartFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5());
             		
 
             }
@@ -1846,7 +1682,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleEndFlowElement"
-    // InternalTestgeneratorDSL.g:768:1: entryRuleEndFlowElement returns [EObject current=null] : iv_ruleEndFlowElement= ruleEndFlowElement EOF ;
+    // InternalTestgeneratorDSL.g:696:1: entryRuleEndFlowElement returns [EObject current=null] : iv_ruleEndFlowElement= ruleEndFlowElement EOF ;
     public final EObject entryRuleEndFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -1854,8 +1690,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:768:55: (iv_ruleEndFlowElement= ruleEndFlowElement EOF )
-            // InternalTestgeneratorDSL.g:769:2: iv_ruleEndFlowElement= ruleEndFlowElement EOF
+            // InternalTestgeneratorDSL.g:696:55: (iv_ruleEndFlowElement= ruleEndFlowElement EOF )
+            // InternalTestgeneratorDSL.g:697:2: iv_ruleEndFlowElement= ruleEndFlowElement EOF
             {
              newCompositeNode(grammarAccess.getEndFlowElementRule()); 
             pushFollow(FOLLOW_1);
@@ -1882,7 +1718,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleEndFlowElement"
-    // InternalTestgeneratorDSL.g:775:1: ruleEndFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:703:1: ruleEndFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleEndFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -1896,21 +1732,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:781:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:782:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:709:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:710:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:782:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:783:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:710:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:711:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'EndEvent' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getEndFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:787:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:788:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:715:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:716:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:788:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:789:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:716:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:717:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
@@ -1932,11 +1768,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_23); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_21); 
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getEndFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,28,FOLLOW_17); 
+            otherlv_3=(Token)match(input,26,FOLLOW_17); 
 
             			newLeafNode(otherlv_3, grammarAccess.getEndFlowElementAccess().getEndEventKeyword_3());
             		
@@ -1967,7 +1803,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleUserTaskFlowElement"
-    // InternalTestgeneratorDSL.g:821:1: entryRuleUserTaskFlowElement returns [EObject current=null] : iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF ;
+    // InternalTestgeneratorDSL.g:749:1: entryRuleUserTaskFlowElement returns [EObject current=null] : iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF ;
     public final EObject entryRuleUserTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -1975,8 +1811,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:821:60: (iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:822:2: iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF
+            // InternalTestgeneratorDSL.g:749:60: (iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:750:2: iv_ruleUserTaskFlowElement= ruleUserTaskFlowElement EOF
             {
              newCompositeNode(grammarAccess.getUserTaskFlowElementRule()); 
             pushFollow(FOLLOW_1);
@@ -2003,7 +1839,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleUserTaskFlowElement"
-    // InternalTestgeneratorDSL.g:828:1: ruleUserTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:756:1: ruleUserTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_16= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleUserTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -2013,60 +1849,39 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         Token otherlv_3=null;
         Token otherlv_4=null;
         Token otherlv_5=null;
-        Token otherlv_6=null;
-        Token this_ASSOCIATION_7=null;
-        Token this_LIST_OPEN_8=null;
-        Token this_SEPARATOR_10=null;
-        Token this_LIST_CLOSED_12=null;
+        Token this_ASSOCIATION_6=null;
+        Token this_LIST_OPEN_7=null;
+        Token this_SEPARATOR_9=null;
+        Token this_LIST_CLOSED_11=null;
+        Token otherlv_12=null;
         Token otherlv_13=null;
-        Token otherlv_14=null;
-        Token this_ASSOCIATION_15=null;
-        Token this_LIST_OPEN_16=null;
-        Token this_SEPARATOR_18=null;
-        Token this_LIST_CLOSED_20=null;
-        Token otherlv_21=null;
-        Token otherlv_22=null;
-        Token this_ASSOCIATION_23=null;
-        Token this_LIST_OPEN_24=null;
-        Token this_SEPARATOR_26=null;
-        Token this_LIST_CLOSED_28=null;
-        Token otherlv_29=null;
-        Token otherlv_30=null;
-        Token this_ASSOCIATION_31=null;
-        Token lv_label_32_0=null;
-        Token this_DECLARATION_FINISHED_33=null;
-        EObject lv_hardcodedInputs_9_0 = null;
-
-        EObject lv_hardcodedInputs_11_0 = null;
+        Token this_ASSOCIATION_14=null;
+        Token lv_label_15_0=null;
+        Token this_DECLARATION_FINISHED_16=null;
+        EObject lv_inputVariables_8_0 = null;
 
-        EObject lv_inputVariables_17_0 = null;
-
-        EObject lv_inputVariables_19_0 = null;
-
-        EObject lv_outputVariables_25_0 = null;
-
-        EObject lv_outputVariables_27_0 = null;
+        EObject lv_inputVariables_10_0 = null;
 
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:834:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:835:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:762:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_16= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:763:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_16= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:835:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:836:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:763:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_16= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:764:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'UserTask' (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )? (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_16= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getUserTaskFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:840:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:841:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:768:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:769:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:841:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:842:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:769:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:770:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
@@ -2088,71 +1903,63 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_24); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_22); 
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,29,FOLLOW_25); 
+            otherlv_3=(Token)match(input,27,FOLLOW_23); 
 
             			newLeafNode(otherlv_3, grammarAccess.getUserTaskFlowElementAccess().getUserTaskKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:866:3: (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )?
-            int alt18=2;
-            int LA18_0 = input.LA(1);
-
-            if ( (LA18_0==17) ) {
-                int LA18_1 = input.LA(2);
+            // InternalTestgeneratorDSL.g:794:3: (otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED )?
+            int alt15=2;
+            int LA15_0 = input.LA(1);
 
-                if ( (LA18_1==25) ) {
-                    alt18=1;
-                }
+            if ( (LA15_0==17) ) {
+                alt15=1;
             }
-            switch (alt18) {
+            switch (alt15) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:867:4: otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:795:4: otherlv_4= 'with' otherlv_5= 'inputVariables' this_ASSOCIATION_6= RULE_ASSOCIATION this_LIST_OPEN_7= RULE_LIST_OPEN ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_11= RULE_LIST_CLOSED
                     {
                     otherlv_4=(Token)match(input,17,FOLLOW_19); 
 
                     				newLeafNode(otherlv_4, grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,25,FOLLOW_20); 
-
-                    				newLeafNode(otherlv_5, grammarAccess.getUserTaskFlowElementAccess().getHardcodedKeyword_4_1());
-                    			
-                    otherlv_6=(Token)match(input,26,FOLLOW_12); 
+                    otherlv_5=(Token)match(input,25,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_6, grammarAccess.getUserTaskFlowElementAccess().getInputsKeyword_4_2());
+                    				newLeafNode(otherlv_5, grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_4_1());
                     			
-                    this_ASSOCIATION_7=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
 
-                    				newLeafNode(this_ASSOCIATION_7, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3());
+                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    this_LIST_OPEN_8=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_LIST_OPEN_7=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
-                    				newLeafNode(this_LIST_OPEN_8, grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4());
+                    				newLeafNode(this_LIST_OPEN_7, grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_3());
                     			
-                    // InternalTestgeneratorDSL.g:887:4: ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )?
-                    int alt17=2;
-                    int LA17_0 = input.LA(1);
+                    // InternalTestgeneratorDSL.g:811:4: ( ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )* )?
+                    int alt14=2;
+                    int LA14_0 = input.LA(1);
 
-                    if ( (LA17_0==RULE_ID) ) {
-                        alt17=1;
+                    if ( (LA14_0==RULE_ID) ) {
+                        alt14=1;
                     }
-                    switch (alt17) {
+                    switch (alt14) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:888:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
+                            // InternalTestgeneratorDSL.g:812:5: ( (lv_inputVariables_8_0= ruleVariableReference ) ) (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )*
                             {
-                            // InternalTestgeneratorDSL.g:888:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:889:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
+                            // InternalTestgeneratorDSL.g:812:5: ( (lv_inputVariables_8_0= ruleVariableReference ) )
+                            // InternalTestgeneratorDSL.g:813:6: (lv_inputVariables_8_0= ruleVariableReference )
                             {
-                            // InternalTestgeneratorDSL.g:889:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:890:7: lv_hardcodedInputs_9_0= ruleVariableDeclaration
+                            // InternalTestgeneratorDSL.g:813:6: (lv_inputVariables_8_0= ruleVariableReference )
+                            // InternalTestgeneratorDSL.g:814:7: lv_inputVariables_8_0= ruleVariableReference
                             {
 
-                            							newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0());
+                            							newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_0_0());
                             						
                             pushFollow(FOLLOW_15);
-                            lv_hardcodedInputs_9_0=ruleVariableDeclaration();
+                            lv_inputVariables_8_0=ruleVariableReference();
 
                             state._fsp--;
 
@@ -2162,9 +1969,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             							}
                             							add(
                             								current,
-                            								"hardcodedInputs",
-                            								lv_hardcodedInputs_9_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
+                            								"inputVariables",
+                            								lv_inputVariables_8_0,
+                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
                             							afterParserOrEnumRuleCall();
                             						
 
@@ -2173,36 +1980,36 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                             }
 
-                            // InternalTestgeneratorDSL.g:907:5: (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
-                            loop16:
+                            // InternalTestgeneratorDSL.g:831:5: (this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) ) )*
+                            loop13:
                             do {
-                                int alt16=2;
-                                int LA16_0 = input.LA(1);
+                                int alt13=2;
+                                int LA13_0 = input.LA(1);
 
-                                if ( (LA16_0==RULE_SEPARATOR) ) {
-                                    alt16=1;
+                                if ( (LA13_0==RULE_SEPARATOR) ) {
+                                    alt13=1;
                                 }
 
 
-                                switch (alt16) {
+                                switch (alt13) {
                             	case 1 :
-                            	    // InternalTestgeneratorDSL.g:908:6: this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
+                            	    // InternalTestgeneratorDSL.g:832:6: this_SEPARATOR_9= RULE_SEPARATOR ( (lv_inputVariables_10_0= ruleVariableReference ) )
                             	    {
-                            	    this_SEPARATOR_10=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+                            	    this_SEPARATOR_9=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
-                            	    						newLeafNode(this_SEPARATOR_10, grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0());
+                            	    						newLeafNode(this_SEPARATOR_9, grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_4_1_0());
                             	    					
-                            	    // InternalTestgeneratorDSL.g:912:6: ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:913:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
+                            	    // InternalTestgeneratorDSL.g:836:6: ( (lv_inputVariables_10_0= ruleVariableReference ) )
+                            	    // InternalTestgeneratorDSL.g:837:7: (lv_inputVariables_10_0= ruleVariableReference )
                             	    {
-                            	    // InternalTestgeneratorDSL.g:913:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:914:8: lv_hardcodedInputs_11_0= ruleVariableDeclaration
+                            	    // InternalTestgeneratorDSL.g:837:7: (lv_inputVariables_10_0= ruleVariableReference )
+                            	    // InternalTestgeneratorDSL.g:838:8: lv_inputVariables_10_0= ruleVariableReference
                             	    {
 
-                            	    								newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0());
+                            	    								newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0());
                             	    							
                             	    pushFollow(FOLLOW_15);
-                            	    lv_hardcodedInputs_11_0=ruleVariableDeclaration();
+                            	    lv_inputVariables_10_0=ruleVariableReference();
 
                             	    state._fsp--;
 
@@ -2212,9 +2019,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    								}
                             	    								add(
                             	    									current,
-                            	    									"hardcodedInputs",
-                            	    									lv_hardcodedInputs_11_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
+                            	    									"inputVariables",
+                            	    									lv_inputVariables_10_0,
+                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
                             	    								afterParserOrEnumRuleCall();
                             	    							
 
@@ -2228,7 +2035,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    break;
 
                             	default :
-                            	    break loop16;
+                            	    break loop13;
                                 }
                             } while (true);
 
@@ -2238,9 +2045,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    this_LIST_CLOSED_12=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
+                    this_LIST_CLOSED_11=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_24); 
 
-                    				newLeafNode(this_LIST_CLOSED_12, grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6());
+                    				newLeafNode(this_LIST_CLOSED_11, grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_5());
                     			
 
                     }
@@ -2248,339 +2055,227 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:938:3: (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )?
-            int alt21=2;
-            int LA21_0 = input.LA(1);
-
-            if ( (LA21_0==17) ) {
-                int LA21_1 = input.LA(2);
+            // InternalTestgeneratorDSL.g:862:3: (otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) ) )?
+            int alt16=2;
+            int LA16_0 = input.LA(1);
 
-                if ( (LA21_1==30) ) {
-                    alt21=1;
-                }
+            if ( (LA16_0==28) ) {
+                alt16=1;
             }
-            switch (alt21) {
+            switch (alt16) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:939:4: otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:863:4: otherlv_12= 'and' otherlv_13= 'label' this_ASSOCIATION_14= RULE_ASSOCIATION ( (lv_label_15_0= RULE_STRING ) )
                     {
-                    otherlv_13=(Token)match(input,17,FOLLOW_26); 
+                    otherlv_12=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_13, grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_5_0());
+                    				newLeafNode(otherlv_12, grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_5_0());
                     			
-                    otherlv_14=(Token)match(input,30,FOLLOW_12); 
+                    otherlv_13=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_14, grammarAccess.getUserTaskFlowElementAccess().getInputVariablesKeyword_5_1());
+                    				newLeafNode(otherlv_13, grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_5_1());
                     			
-                    this_ASSOCIATION_15=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    this_ASSOCIATION_14=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(this_ASSOCIATION_15, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
+                    				newLeafNode(this_ASSOCIATION_14, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
                     			
-                    this_LIST_OPEN_16=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    // InternalTestgeneratorDSL.g:875:4: ( (lv_label_15_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:876:5: (lv_label_15_0= RULE_STRING )
+                    {
+                    // InternalTestgeneratorDSL.g:876:5: (lv_label_15_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:877:6: lv_label_15_0= RULE_STRING
+                    {
+                    lv_label_15_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                    				newLeafNode(this_LIST_OPEN_16, grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3());
-                    			
-                    // InternalTestgeneratorDSL.g:955:4: ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )?
-                    int alt20=2;
-                    int LA20_0 = input.LA(1);
+                    						newLeafNode(lv_label_15_0, grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0());
+                    					
 
-                    if ( (LA20_0==RULE_ID) ) {
-                        alt20=1;
-                    }
-                    switch (alt20) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:956:5: ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:956:5: ( (lv_inputVariables_17_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:957:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:957:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:958:7: lv_inputVariables_17_0= ruleVariableReference
-                            {
+                    						if (current==null) {
+                    							current = createModelElement(grammarAccess.getUserTaskFlowElementRule());
+                    						}
+                    						setWithLastConsumed(
+                    							current,
+                    							"label",
+                    							lv_label_15_0,
+                    							"org.eclipse.xtext.common.Terminals.STRING");
+                    					
 
-                            							newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_inputVariables_17_0=ruleVariableReference();
+                    }
 
-                            state._fsp--;
 
+                    }
 
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getUserTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"inputVariables",
-                            								lv_inputVariables_17_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
 
-                            }
+                    }
+                    break;
 
+            }
 
-                            }
+            this_DECLARATION_FINISHED_16=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-                            // InternalTestgeneratorDSL.g:975:5: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            loop19:
-                            do {
-                                int alt19=2;
-                                int LA19_0 = input.LA(1);
+            			newLeafNode(this_DECLARATION_FINISHED_16, grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6());
+            		
 
-                                if ( (LA19_0==RULE_SEPARATOR) ) {
-                                    alt19=1;
-                                }
+            }
 
 
-                                switch (alt19) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:976:6: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_18=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+            }
 
-                            	    						newLeafNode(this_SEPARATOR_18, grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:980:6: ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:981:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:981:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:982:8: lv_inputVariables_19_0= ruleVariableReference
-                            	    {
 
-                            	    								newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_inputVariables_19_0=ruleVariableReference();
+            	leaveRule();
 
-                            	    state._fsp--;
+        }
 
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
+            }
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "ruleUserTaskFlowElement"
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getUserTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"inputVariables",
-                            	    									lv_inputVariables_19_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop19;
-                                }
-                            } while (true);
 
+    // $ANTLR start "entryRuleManualTaskFlowElement"
+    // InternalTestgeneratorDSL.g:902:1: entryRuleManualTaskFlowElement returns [EObject current=null] : iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF ;
+    public final EObject entryRuleManualTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                            }
-                            break;
+        EObject iv_ruleManualTaskFlowElement = null;
 
-                    }
 
-                    this_LIST_CLOSED_20=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
+        try {
+            // InternalTestgeneratorDSL.g:902:62: (iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:903:2: iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF
+            {
+             newCompositeNode(grammarAccess.getManualTaskFlowElementRule()); 
+            pushFollow(FOLLOW_1);
+            iv_ruleManualTaskFlowElement=ruleManualTaskFlowElement();
 
-                    				newLeafNode(this_LIST_CLOSED_20, grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5());
-                    			
+            state._fsp--;
 
-                    }
-                    break;
+             current =iv_ruleManualTaskFlowElement; 
+            match(input,EOF,FOLLOW_2); 
 
             }
 
-            // InternalTestgeneratorDSL.g:1006:3: (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )?
-            int alt24=2;
-            int LA24_0 = input.LA(1);
+        }
 
-            if ( (LA24_0==17) ) {
-                alt24=1;
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
             }
-            switch (alt24) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1007:4: otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED
-                    {
-                    otherlv_21=(Token)match(input,17,FOLLOW_27); 
-
-                    				newLeafNode(otherlv_21, grammarAccess.getUserTaskFlowElementAccess().getWithKeyword_6_0());
-                    			
-                    otherlv_22=(Token)match(input,31,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_22, grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesKeyword_6_1());
-                    			
-                    this_ASSOCIATION_23=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_23, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2());
-                    			
-                    this_LIST_OPEN_24=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_24, grammarAccess.getUserTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3());
-                    			
-                    // InternalTestgeneratorDSL.g:1023:4: ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )?
-                    int alt23=2;
-                    int LA23_0 = input.LA(1);
-
-                    if ( (LA23_0==RULE_ID) ) {
-                        alt23=1;
-                    }
-                    switch (alt23) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1024:5: ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1024:5: ( (lv_outputVariables_25_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:1025:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:1025:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:1026:7: lv_outputVariables_25_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_outputVariables_25_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getUserTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"outputVariables",
-                            								lv_outputVariables_25_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1043:5: (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            loop22:
-                            do {
-                                int alt22=2;
-                                int LA22_0 = input.LA(1);
-
-                                if ( (LA22_0==RULE_SEPARATOR) ) {
-                                    alt22=1;
-                                }
-
-
-                                switch (alt22) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1044:6: this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_26=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_26, grammarAccess.getUserTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1048:6: ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:1049:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1049:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:1050:8: lv_outputVariables_27_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getUserTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_outputVariables_27_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "entryRuleManualTaskFlowElement"
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getUserTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"outputVariables",
-                            	    									lv_outputVariables_27_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
 
-                            	    }
+    // $ANTLR start "ruleManualTaskFlowElement"
+    // InternalTestgeneratorDSL.g:909:1: ruleManualTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
+    public final EObject ruleManualTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
+        Token otherlv_0=null;
+        Token lv_name_1_0=null;
+        Token this_ASSOCIATION_2=null;
+        Token otherlv_3=null;
+        Token otherlv_4=null;
+        Token otherlv_5=null;
+        Token this_ASSOCIATION_6=null;
+        Token lv_label_7_0=null;
+        Token this_DECLARATION_FINISHED_8=null;
 
-                            	    }
 
+        	enterRule();
 
-                            	    }
-                            	    break;
+        try {
+            // InternalTestgeneratorDSL.g:915:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:916:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            {
+            // InternalTestgeneratorDSL.g:916:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:917:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
+            {
+            otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
-                            	default :
-                            	    break loop22;
-                                }
-                            } while (true);
+            			newLeafNode(otherlv_0, grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0());
+            		
+            // InternalTestgeneratorDSL.g:921:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:922:4: (lv_name_1_0= RULE_ID )
+            {
+            // InternalTestgeneratorDSL.g:922:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:923:5: lv_name_1_0= RULE_ID
+            {
+            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
+            					newLeafNode(lv_name_1_0, grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
+            				
 
-                            }
-                            break;
+            					if (current==null) {
+            						current = createModelElement(grammarAccess.getManualTaskFlowElementRule());
+            					}
+            					setWithLastConsumed(
+            						current,
+            						"name",
+            						lv_name_1_0,
+            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
+            				
 
-                    }
+            }
 
-                    this_LIST_CLOSED_28=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_28); 
 
-                    				newLeafNode(this_LIST_CLOSED_28, grammarAccess.getUserTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5());
-                    			
+            }
 
-                    }
-                    break;
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_26); 
 
-            }
+            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
+            		
+            otherlv_3=(Token)match(input,30,FOLLOW_24); 
 
-            // InternalTestgeneratorDSL.g:1074:3: (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )?
-            int alt25=2;
-            int LA25_0 = input.LA(1);
+            			newLeafNode(otherlv_3, grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3());
+            		
+            // InternalTestgeneratorDSL.g:947:3: (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )?
+            int alt17=2;
+            int LA17_0 = input.LA(1);
 
-            if ( (LA25_0==32) ) {
-                alt25=1;
+            if ( (LA17_0==28) ) {
+                alt17=1;
             }
-            switch (alt25) {
+            switch (alt17) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:1075:4: otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:948:4: otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) )
                     {
-                    otherlv_29=(Token)match(input,32,FOLLOW_29); 
+                    otherlv_4=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_29, grammarAccess.getUserTaskFlowElementAccess().getAndKeyword_7_0());
+                    				newLeafNode(otherlv_4, grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_4_0());
                     			
-                    otherlv_30=(Token)match(input,33,FOLLOW_12); 
+                    otherlv_5=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_30, grammarAccess.getUserTaskFlowElementAccess().getLabelKeyword_7_1());
+                    				newLeafNode(otherlv_5, grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_4_1());
                     			
-                    this_ASSOCIATION_31=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(this_ASSOCIATION_31, grammarAccess.getUserTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2());
+                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    // InternalTestgeneratorDSL.g:1087:4: ( (lv_label_32_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:1088:5: (lv_label_32_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:960:4: ( (lv_label_7_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:961:5: (lv_label_7_0= RULE_STRING )
                     {
-                    // InternalTestgeneratorDSL.g:1088:5: (lv_label_32_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:1089:6: lv_label_32_0= RULE_STRING
+                    // InternalTestgeneratorDSL.g:961:5: (lv_label_7_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:962:6: lv_label_7_0= RULE_STRING
                     {
-                    lv_label_32_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
+                    lv_label_7_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                    						newLeafNode(lv_label_32_0, grammarAccess.getUserTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0());
+                    						newLeafNode(lv_label_7_0, grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0());
                     					
 
                     						if (current==null) {
-                    							current = createModelElement(grammarAccess.getUserTaskFlowElementRule());
+                    							current = createModelElement(grammarAccess.getManualTaskFlowElementRule());
                     						}
                     						setWithLastConsumed(
                     							current,
                     							"label",
-                    							lv_label_32_0,
+                    							lv_label_7_0,
                     							"org.eclipse.xtext.common.Terminals.STRING");
                     					
 
@@ -2595,9 +2290,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_DECLARATION_FINISHED_33=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+            this_DECLARATION_FINISHED_8=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-            			newLeafNode(this_DECLARATION_FINISHED_33, grammarAccess.getUserTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8());
+            			newLeafNode(this_DECLARATION_FINISHED_8, grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5());
             		
 
             }
@@ -2618,28 +2313,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         }
         return current;
     }
-    // $ANTLR end "ruleUserTaskFlowElement"
+    // $ANTLR end "ruleManualTaskFlowElement"
 
 
-    // $ANTLR start "entryRuleManualTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1114:1: entryRuleManualTaskFlowElement returns [EObject current=null] : iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF ;
-    public final EObject entryRuleManualTaskFlowElement() throws RecognitionException {
+    // $ANTLR start "entryRuleScriptTaskFlowElement"
+    // InternalTestgeneratorDSL.g:987:1: entryRuleScriptTaskFlowElement returns [EObject current=null] : iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF ;
+    public final EObject entryRuleScriptTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
-        EObject iv_ruleManualTaskFlowElement = null;
+        EObject iv_ruleScriptTaskFlowElement = null;
 
 
         try {
-            // InternalTestgeneratorDSL.g:1114:62: (iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:1115:2: iv_ruleManualTaskFlowElement= ruleManualTaskFlowElement EOF
+            // InternalTestgeneratorDSL.g:987:62: (iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:988:2: iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF
             {
-             newCompositeNode(grammarAccess.getManualTaskFlowElementRule()); 
+             newCompositeNode(grammarAccess.getScriptTaskFlowElementRule()); 
             pushFollow(FOLLOW_1);
-            iv_ruleManualTaskFlowElement=ruleManualTaskFlowElement();
+            iv_ruleScriptTaskFlowElement=ruleScriptTaskFlowElement();
 
             state._fsp--;
 
-             current =iv_ruleManualTaskFlowElement; 
+             current =iv_ruleScriptTaskFlowElement; 
             match(input,EOF,FOLLOW_2); 
 
             }
@@ -2654,12 +2349,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         }
         return current;
     }
-    // $ANTLR end "entryRuleManualTaskFlowElement"
+    // $ANTLR end "entryRuleScriptTaskFlowElement"
 
 
-    // $ANTLR start "ruleManualTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1121:1: ruleManualTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) ;
-    public final EObject ruleManualTaskFlowElement() throws RecognitionException {
+    // $ANTLR start "ruleScriptTaskFlowElement"
+    // InternalTestgeneratorDSL.g:994:1: ruleScriptTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
+    public final EObject ruleScriptTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
         Token otherlv_0=null;
@@ -2668,68 +2363,37 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         Token otherlv_3=null;
         Token otherlv_4=null;
         Token otherlv_5=null;
-        Token otherlv_6=null;
-        Token this_ASSOCIATION_7=null;
-        Token this_LIST_OPEN_8=null;
-        Token this_SEPARATOR_10=null;
-        Token this_LIST_CLOSED_12=null;
-        Token otherlv_13=null;
-        Token otherlv_14=null;
-        Token this_ASSOCIATION_15=null;
-        Token this_LIST_OPEN_16=null;
-        Token this_SEPARATOR_18=null;
-        Token this_LIST_CLOSED_20=null;
-        Token otherlv_21=null;
-        Token otherlv_22=null;
-        Token this_ASSOCIATION_23=null;
-        Token this_LIST_OPEN_24=null;
-        Token this_SEPARATOR_26=null;
-        Token this_LIST_CLOSED_28=null;
-        Token otherlv_29=null;
-        Token otherlv_30=null;
-        Token this_ASSOCIATION_31=null;
-        Token lv_label_32_0=null;
-        Token this_DECLARATION_FINISHED_33=null;
-        EObject lv_hardcodedInputs_9_0 = null;
-
-        EObject lv_hardcodedInputs_11_0 = null;
-
-        EObject lv_inputVariables_17_0 = null;
-
-        EObject lv_inputVariables_19_0 = null;
-
-        EObject lv_outputVariables_25_0 = null;
-
-        EObject lv_outputVariables_27_0 = null;
-
+        Token this_ASSOCIATION_6=null;
+        Token lv_label_7_0=null;
+        Token this_DECLARATION_FINISHED_8=null;
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:1127:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:1128:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1000:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1001:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:1128:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:1129:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ManualTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1001:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1002:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
-            			newLeafNode(otherlv_0, grammarAccess.getManualTaskFlowElementAccess().getFlowElementKeyword_0());
+            			newLeafNode(otherlv_0, grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:1133:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:1134:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1006:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1007:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:1134:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:1135:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1007:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1008:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
-            					newLeafNode(lv_name_1_0, grammarAccess.getManualTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
+            					newLeafNode(lv_name_1_0, grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
             				
 
             					if (current==null) {
-            						current = createModelElement(grammarAccess.getManualTaskFlowElementRule());
+            						current = createModelElement(grammarAccess.getScriptTaskFlowElementRule());
             					}
             					setWithLastConsumed(
             						current,
@@ -2743,2257 +2407,455 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_30); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_27); 
 
-            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
+            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,34,FOLLOW_25); 
+            otherlv_3=(Token)match(input,31,FOLLOW_24); 
 
-            			newLeafNode(otherlv_3, grammarAccess.getManualTaskFlowElementAccess().getManualTaskKeyword_3());
+            			newLeafNode(otherlv_3, grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:1159:3: (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )?
-            int alt28=2;
-            int LA28_0 = input.LA(1);
-
-            if ( (LA28_0==17) ) {
-                int LA28_1 = input.LA(2);
+            // InternalTestgeneratorDSL.g:1032:3: (otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) ) )?
+            int alt18=2;
+            int LA18_0 = input.LA(1);
 
-                if ( (LA28_1==25) ) {
-                    alt28=1;
-                }
+            if ( (LA18_0==28) ) {
+                alt18=1;
             }
-            switch (alt28) {
+            switch (alt18) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:1160:4: otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:1033:4: otherlv_4= 'and' otherlv_5= 'label' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_label_7_0= RULE_STRING ) )
                     {
-                    otherlv_4=(Token)match(input,17,FOLLOW_19); 
+                    otherlv_4=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_4, grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_4_0());
+                    				newLeafNode(otherlv_4, grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,25,FOLLOW_20); 
+                    otherlv_5=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_5, grammarAccess.getManualTaskFlowElementAccess().getHardcodedKeyword_4_1());
+                    				newLeafNode(otherlv_5, grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_4_1());
                     			
-                    otherlv_6=(Token)match(input,26,FOLLOW_12); 
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(otherlv_6, grammarAccess.getManualTaskFlowElementAccess().getInputsKeyword_4_2());
+                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    this_ASSOCIATION_7=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    // InternalTestgeneratorDSL.g:1045:4: ( (lv_label_7_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1046:5: (lv_label_7_0= RULE_STRING )
+                    {
+                    // InternalTestgeneratorDSL.g:1046:5: (lv_label_7_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1047:6: lv_label_7_0= RULE_STRING
+                    {
+                    lv_label_7_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                    				newLeafNode(this_ASSOCIATION_7, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3());
-                    			
-                    this_LIST_OPEN_8=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    						newLeafNode(lv_label_7_0, grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_4_3_0());
+                    					
 
-                    				newLeafNode(this_LIST_OPEN_8, grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4());
-                    			
-                    // InternalTestgeneratorDSL.g:1180:4: ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )?
-                    int alt27=2;
-                    int LA27_0 = input.LA(1);
+                    						if (current==null) {
+                    							current = createModelElement(grammarAccess.getScriptTaskFlowElementRule());
+                    						}
+                    						setWithLastConsumed(
+                    							current,
+                    							"label",
+                    							lv_label_7_0,
+                    							"org.eclipse.xtext.common.Terminals.STRING");
+                    					
 
-                    if ( (LA27_0==RULE_ID) ) {
-                        alt27=1;
                     }
-                    switch (alt27) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1181:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1181:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:1182:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            {
-                            // InternalTestgeneratorDSL.g:1182:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:1183:7: lv_hardcodedInputs_9_0= ruleVariableDeclaration
-                            {
 
-                            							newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_hardcodedInputs_9_0=ruleVariableDeclaration();
 
-                            state._fsp--;
+                    }
 
 
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"hardcodedInputs",
-                            								lv_hardcodedInputs_9_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            							afterParserOrEnumRuleCall();
-                            						
+                    }
+                    break;
 
-                            }
+            }
 
+            this_DECLARATION_FINISHED_8=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-                            }
-
-                            // InternalTestgeneratorDSL.g:1200:5: (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
-                            loop26:
-                            do {
-                                int alt26=2;
-                                int LA26_0 = input.LA(1);
-
-                                if ( (LA26_0==RULE_SEPARATOR) ) {
-                                    alt26=1;
-                                }
-
-
-                                switch (alt26) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1201:6: this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    {
-                            	    this_SEPARATOR_10=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_10, grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1205:6: ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:1206:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1206:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:1207:8: lv_hardcodedInputs_11_0= ruleVariableDeclaration
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_hardcodedInputs_11_0=ruleVariableDeclaration();
-
-                            	    state._fsp--;
+            			newLeafNode(this_DECLARATION_FINISHED_8, grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_5());
+            		
 
+            }
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"hardcodedInputs",
-                            	    									lv_hardcodedInputs_11_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
 
-                            	    }
+            }
 
 
-                            	    }
+            	leaveRule();
 
+        }
 
-                            	    }
-                            	    break;
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
+            }
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "ruleScriptTaskFlowElement"
 
-                            	default :
-                            	    break loop26;
-                                }
-                            } while (true);
 
+    // $ANTLR start "entryRuleServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1072:1: entryRuleServiceTaskFlowElement returns [EObject current=null] : iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF ;
+    public final EObject entryRuleServiceTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                            }
-                            break;
+        EObject iv_ruleServiceTaskFlowElement = null;
 
-                    }
 
-                    this_LIST_CLOSED_12=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
+        try {
+            // InternalTestgeneratorDSL.g:1072:63: (iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1073:2: iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF
+            {
+             newCompositeNode(grammarAccess.getServiceTaskFlowElementRule()); 
+            pushFollow(FOLLOW_1);
+            iv_ruleServiceTaskFlowElement=ruleServiceTaskFlowElement();
 
-                    				newLeafNode(this_LIST_CLOSED_12, grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6());
-                    			
+            state._fsp--;
 
-                    }
-                    break;
+             current =iv_ruleServiceTaskFlowElement; 
+            match(input,EOF,FOLLOW_2); 
 
             }
 
-            // InternalTestgeneratorDSL.g:1231:3: (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )?
-            int alt31=2;
-            int LA31_0 = input.LA(1);
-
-            if ( (LA31_0==17) ) {
-                int LA31_1 = input.LA(2);
+        }
 
-                if ( (LA31_1==30) ) {
-                    alt31=1;
-                }
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
             }
-            switch (alt31) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1232:4: otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED
-                    {
-                    otherlv_13=(Token)match(input,17,FOLLOW_26); 
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "entryRuleServiceTaskFlowElement"
 
-                    				newLeafNode(otherlv_13, grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_5_0());
-                    			
-                    otherlv_14=(Token)match(input,30,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_14, grammarAccess.getManualTaskFlowElementAccess().getInputVariablesKeyword_5_1());
-                    			
-                    this_ASSOCIATION_15=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+    // $ANTLR start "ruleServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1079:1: ruleServiceTaskFlowElement returns [EObject current=null] : (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement ) ;
+    public final EObject ruleServiceTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                    				newLeafNode(this_ASSOCIATION_15, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
-                    			
-                    this_LIST_OPEN_16=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+        EObject this_DelegateServiceTaskFlowElement_0 = null;
 
-                    				newLeafNode(this_LIST_OPEN_16, grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3());
-                    			
-                    // InternalTestgeneratorDSL.g:1248:4: ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )?
-                    int alt30=2;
-                    int LA30_0 = input.LA(1);
+        EObject this_ExternalServiceTaskFlowElement_1 = null;
 
-                    if ( (LA30_0==RULE_ID) ) {
-                        alt30=1;
-                    }
-                    switch (alt30) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1249:5: ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1249:5: ( (lv_inputVariables_17_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:1250:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:1250:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:1251:7: lv_inputVariables_17_0= ruleVariableReference
-                            {
 
-                            							newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_inputVariables_17_0=ruleVariableReference();
 
-                            state._fsp--;
+        	enterRule();
 
+        try {
+            // InternalTestgeneratorDSL.g:1085:2: ( (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement ) )
+            // InternalTestgeneratorDSL.g:1086:2: (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement )
+            {
+            // InternalTestgeneratorDSL.g:1086:2: (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement )
+            int alt19=2;
+            int LA19_0 = input.LA(1);
 
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"inputVariables",
-                            								lv_inputVariables_17_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
+            if ( (LA19_0==23) ) {
+                int LA19_1 = input.LA(2);
 
-                            }
+                if ( (LA19_1==RULE_ID) ) {
+                    int LA19_2 = input.LA(3);
 
+                    if ( (LA19_2==RULE_ASSOCIATION) ) {
+                        int LA19_3 = input.LA(4);
 
-                            }
+                        if ( (LA19_3==32) ) {
+                            int LA19_4 = input.LA(5);
 
-                            // InternalTestgeneratorDSL.g:1268:5: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            loop29:
-                            do {
-                                int alt29=2;
-                                int LA29_0 = input.LA(1);
+                            if ( (LA19_4==17) ) {
+                                int LA19_5 = input.LA(6);
 
-                                if ( (LA29_0==RULE_SEPARATOR) ) {
-                                    alt29=1;
+                                if ( (LA19_5==33) ) {
+                                    alt19=1;
                                 }
-
-
-                                switch (alt29) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1269:6: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_18=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_18, grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1273:6: ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:1274:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1274:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:1275:8: lv_inputVariables_19_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_inputVariables_19_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"inputVariables",
-                            	    									lv_inputVariables_19_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop29;
+                                else if ( (LA19_5==34) ) {
+                                    alt19=2;
                                 }
-                            } while (true);
+                                else {
+                                    NoViableAltException nvae =
+                                        new NoViableAltException("", 19, 5, input);
 
+                                    throw nvae;
+                                }
+                            }
+                            else {
+                                NoViableAltException nvae =
+                                    new NoViableAltException("", 19, 4, input);
 
+                                throw nvae;
                             }
-                            break;
+                        }
+                        else {
+                            NoViableAltException nvae =
+                                new NoViableAltException("", 19, 3, input);
 
+                            throw nvae;
+                        }
                     }
+                    else {
+                        NoViableAltException nvae =
+                            new NoViableAltException("", 19, 2, input);
 
-                    this_LIST_CLOSED_20=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
-
-                    				newLeafNode(this_LIST_CLOSED_20, grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5());
-                    			
-
+                        throw nvae;
                     }
-                    break;
+                }
+                else {
+                    NoViableAltException nvae =
+                        new NoViableAltException("", 19, 1, input);
 
+                    throw nvae;
+                }
             }
+            else {
+                NoViableAltException nvae =
+                    new NoViableAltException("", 19, 0, input);
 
-            // InternalTestgeneratorDSL.g:1299:3: (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )?
-            int alt34=2;
-            int LA34_0 = input.LA(1);
-
-            if ( (LA34_0==17) ) {
-                alt34=1;
+                throw nvae;
             }
-            switch (alt34) {
+            switch (alt19) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:1300:4: otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:1087:3: this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement
                     {
-                    otherlv_21=(Token)match(input,17,FOLLOW_27); 
 
-                    				newLeafNode(otherlv_21, grammarAccess.getManualTaskFlowElementAccess().getWithKeyword_6_0());
-                    			
-                    otherlv_22=(Token)match(input,31,FOLLOW_12); 
+                    			newCompositeNode(grammarAccess.getServiceTaskFlowElementAccess().getDelegateServiceTaskFlowElementParserRuleCall_0());
+                    		
+                    pushFollow(FOLLOW_2);
+                    this_DelegateServiceTaskFlowElement_0=ruleDelegateServiceTaskFlowElement();
 
-                    				newLeafNode(otherlv_22, grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesKeyword_6_1());
-                    			
-                    this_ASSOCIATION_23=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    state._fsp--;
 
-                    				newLeafNode(this_ASSOCIATION_23, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2());
-                    			
-                    this_LIST_OPEN_24=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
 
-                    				newLeafNode(this_LIST_OPEN_24, grammarAccess.getManualTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3());
-                    			
-                    // InternalTestgeneratorDSL.g:1316:4: ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )?
-                    int alt33=2;
-                    int LA33_0 = input.LA(1);
+                    			current = this_DelegateServiceTaskFlowElement_0;
+                    			afterParserOrEnumRuleCall();
+                    		
 
-                    if ( (LA33_0==RULE_ID) ) {
-                        alt33=1;
                     }
-                    switch (alt33) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1317:5: ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1317:5: ( (lv_outputVariables_25_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:1318:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:1318:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:1319:7: lv_outputVariables_25_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_outputVariables_25_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"outputVariables",
-                            								lv_outputVariables_25_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1336:5: (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            loop32:
-                            do {
-                                int alt32=2;
-                                int LA32_0 = input.LA(1);
-
-                                if ( (LA32_0==RULE_SEPARATOR) ) {
-                                    alt32=1;
-                                }
-
-
-                                switch (alt32) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1337:6: this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_26=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_26, grammarAccess.getManualTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1341:6: ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:1342:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1342:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:1343:8: lv_outputVariables_27_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getManualTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_outputVariables_27_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getManualTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"outputVariables",
-                            	    									lv_outputVariables_27_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop32;
-                                }
-                            } while (true);
-
+                    break;
+                case 2 :
+                    // InternalTestgeneratorDSL.g:1096:3: this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement
+                    {
 
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_28=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_28); 
-
-                    				newLeafNode(this_LIST_CLOSED_28, grammarAccess.getManualTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:1367:3: (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )?
-            int alt35=2;
-            int LA35_0 = input.LA(1);
-
-            if ( (LA35_0==32) ) {
-                alt35=1;
-            }
-            switch (alt35) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1368:4: otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) )
-                    {
-                    otherlv_29=(Token)match(input,32,FOLLOW_29); 
-
-                    				newLeafNode(otherlv_29, grammarAccess.getManualTaskFlowElementAccess().getAndKeyword_7_0());
-                    			
-                    otherlv_30=(Token)match(input,33,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_30, grammarAccess.getManualTaskFlowElementAccess().getLabelKeyword_7_1());
-                    			
-                    this_ASSOCIATION_31=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
-
-                    				newLeafNode(this_ASSOCIATION_31, grammarAccess.getManualTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2());
-                    			
-                    // InternalTestgeneratorDSL.g:1380:4: ( (lv_label_32_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:1381:5: (lv_label_32_0= RULE_STRING )
-                    {
-                    // InternalTestgeneratorDSL.g:1381:5: (lv_label_32_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:1382:6: lv_label_32_0= RULE_STRING
-                    {
-                    lv_label_32_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
-
-                    						newLeafNode(lv_label_32_0, grammarAccess.getManualTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0());
-                    					
-
-                    						if (current==null) {
-                    							current = createModelElement(grammarAccess.getManualTaskFlowElementRule());
-                    						}
-                    						setWithLastConsumed(
-                    							current,
-                    							"label",
-                    							lv_label_32_0,
-                    							"org.eclipse.xtext.common.Terminals.STRING");
-                    					
-
-                    }
-
-
-                    }
-
-
-                    }
-                    break;
-
-            }
-
-            this_DECLARATION_FINISHED_33=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-
-            			newLeafNode(this_DECLARATION_FINISHED_33, grammarAccess.getManualTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8());
-            		
-
-            }
-
-
-            }
-
-
-            	leaveRule();
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "ruleManualTaskFlowElement"
-
-
-    // $ANTLR start "entryRuleScriptTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1407:1: entryRuleScriptTaskFlowElement returns [EObject current=null] : iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF ;
-    public final EObject entryRuleScriptTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        EObject iv_ruleScriptTaskFlowElement = null;
-
-
-        try {
-            // InternalTestgeneratorDSL.g:1407:62: (iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:1408:2: iv_ruleScriptTaskFlowElement= ruleScriptTaskFlowElement EOF
-            {
-             newCompositeNode(grammarAccess.getScriptTaskFlowElementRule()); 
-            pushFollow(FOLLOW_1);
-            iv_ruleScriptTaskFlowElement=ruleScriptTaskFlowElement();
-
-            state._fsp--;
-
-             current =iv_ruleScriptTaskFlowElement; 
-            match(input,EOF,FOLLOW_2); 
-
-            }
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "entryRuleScriptTaskFlowElement"
-
-
-    // $ANTLR start "ruleScriptTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1414:1: ruleScriptTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) ;
-    public final EObject ruleScriptTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        Token otherlv_0=null;
-        Token lv_name_1_0=null;
-        Token this_ASSOCIATION_2=null;
-        Token otherlv_3=null;
-        Token otherlv_4=null;
-        Token otherlv_5=null;
-        Token otherlv_6=null;
-        Token this_ASSOCIATION_7=null;
-        Token this_LIST_OPEN_8=null;
-        Token this_SEPARATOR_10=null;
-        Token this_LIST_CLOSED_12=null;
-        Token otherlv_13=null;
-        Token otherlv_14=null;
-        Token this_ASSOCIATION_15=null;
-        Token this_LIST_OPEN_16=null;
-        Token this_SEPARATOR_18=null;
-        Token this_LIST_CLOSED_20=null;
-        Token otherlv_21=null;
-        Token otherlv_22=null;
-        Token this_ASSOCIATION_23=null;
-        Token this_LIST_OPEN_24=null;
-        Token this_SEPARATOR_26=null;
-        Token this_LIST_CLOSED_28=null;
-        Token otherlv_29=null;
-        Token otherlv_30=null;
-        Token this_ASSOCIATION_31=null;
-        Token lv_label_32_0=null;
-        Token this_DECLARATION_FINISHED_33=null;
-        EObject lv_hardcodedInputs_9_0 = null;
-
-        EObject lv_hardcodedInputs_11_0 = null;
-
-        EObject lv_inputVariables_17_0 = null;
-
-        EObject lv_inputVariables_19_0 = null;
-
-        EObject lv_outputVariables_25_0 = null;
-
-        EObject lv_outputVariables_27_0 = null;
-
-
-
-        	enterRule();
-
-        try {
-            // InternalTestgeneratorDSL.g:1420:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:1421:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:1421:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:1422:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ScriptTask' (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )? (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )? (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )? (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_33= RULE_DECLARATION_FINISHED
-            {
-            otherlv_0=(Token)match(input,23,FOLLOW_4); 
-
-            			newLeafNode(otherlv_0, grammarAccess.getScriptTaskFlowElementAccess().getFlowElementKeyword_0());
-            		
-            // InternalTestgeneratorDSL.g:1426:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:1427:4: (lv_name_1_0= RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:1427:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:1428:5: lv_name_1_0= RULE_ID
-            {
-            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
-
-            					newLeafNode(lv_name_1_0, grammarAccess.getScriptTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
-            				
-
-            					if (current==null) {
-            						current = createModelElement(grammarAccess.getScriptTaskFlowElementRule());
-            					}
-            					setWithLastConsumed(
-            						current,
-            						"name",
-            						lv_name_1_0,
-            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
-            				
-
-            }
-
-
-            }
-
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_31); 
-
-            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
-            		
-            otherlv_3=(Token)match(input,35,FOLLOW_25); 
-
-            			newLeafNode(otherlv_3, grammarAccess.getScriptTaskFlowElementAccess().getScriptTaskKeyword_3());
-            		
-            // InternalTestgeneratorDSL.g:1452:3: (otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED )?
-            int alt38=2;
-            int LA38_0 = input.LA(1);
-
-            if ( (LA38_0==17) ) {
-                int LA38_1 = input.LA(2);
-
-                if ( (LA38_1==25) ) {
-                    alt38=1;
-                }
-            }
-            switch (alt38) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1453:4: otherlv_4= 'with' otherlv_5= 'hardcoded' otherlv_6= 'inputs' this_ASSOCIATION_7= RULE_ASSOCIATION this_LIST_OPEN_8= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_12= RULE_LIST_CLOSED
-                    {
-                    otherlv_4=(Token)match(input,17,FOLLOW_19); 
-
-                    				newLeafNode(otherlv_4, grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_4_0());
-                    			
-                    otherlv_5=(Token)match(input,25,FOLLOW_20); 
-
-                    				newLeafNode(otherlv_5, grammarAccess.getScriptTaskFlowElementAccess().getHardcodedKeyword_4_1());
-                    			
-                    otherlv_6=(Token)match(input,26,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_6, grammarAccess.getScriptTaskFlowElementAccess().getInputsKeyword_4_2());
-                    			
-                    this_ASSOCIATION_7=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_7, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_3());
-                    			
-                    this_LIST_OPEN_8=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_8, grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_4_4());
-                    			
-                    // InternalTestgeneratorDSL.g:1473:4: ( ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )* )?
-                    int alt37=2;
-                    int LA37_0 = input.LA(1);
-
-                    if ( (LA37_0==RULE_ID) ) {
-                        alt37=1;
-                    }
-                    switch (alt37) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1474:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) ) (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1474:5: ( (lv_hardcodedInputs_9_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:1475:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            {
-                            // InternalTestgeneratorDSL.g:1475:6: (lv_hardcodedInputs_9_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:1476:7: lv_hardcodedInputs_9_0= ruleVariableDeclaration
-                            {
-
-                            							newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_hardcodedInputs_9_0=ruleVariableDeclaration();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"hardcodedInputs",
-                            								lv_hardcodedInputs_9_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1493:5: (this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) ) )*
-                            loop36:
-                            do {
-                                int alt36=2;
-                                int LA36_0 = input.LA(1);
-
-                                if ( (LA36_0==RULE_SEPARATOR) ) {
-                                    alt36=1;
-                                }
-
-
-                                switch (alt36) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1494:6: this_SEPARATOR_10= RULE_SEPARATOR ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    {
-                            	    this_SEPARATOR_10=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_10, grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_4_5_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1498:6: ( (lv_hardcodedInputs_11_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:1499:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1499:7: (lv_hardcodedInputs_11_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:1500:8: lv_hardcodedInputs_11_0= ruleVariableDeclaration
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_hardcodedInputs_11_0=ruleVariableDeclaration();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"hardcodedInputs",
-                            	    									lv_hardcodedInputs_11_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop36;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_12=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
-
-                    				newLeafNode(this_LIST_CLOSED_12, grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_4_6());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:1524:3: (otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED )?
-            int alt41=2;
-            int LA41_0 = input.LA(1);
-
-            if ( (LA41_0==17) ) {
-                int LA41_1 = input.LA(2);
-
-                if ( (LA41_1==30) ) {
-                    alt41=1;
-                }
-            }
-            switch (alt41) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1525:4: otherlv_13= 'with' otherlv_14= 'inputVariables' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED
-                    {
-                    otherlv_13=(Token)match(input,17,FOLLOW_26); 
-
-                    				newLeafNode(otherlv_13, grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_5_0());
-                    			
-                    otherlv_14=(Token)match(input,30,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_14, grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesKeyword_5_1());
-                    			
-                    this_ASSOCIATION_15=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_15, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
-                    			
-                    this_LIST_OPEN_16=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_16, grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_3());
-                    			
-                    // InternalTestgeneratorDSL.g:1541:4: ( ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )* )?
-                    int alt40=2;
-                    int LA40_0 = input.LA(1);
-
-                    if ( (LA40_0==RULE_ID) ) {
-                        alt40=1;
-                    }
-                    switch (alt40) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1542:5: ( (lv_inputVariables_17_0= ruleVariableReference ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1542:5: ( (lv_inputVariables_17_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:1543:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:1543:6: (lv_inputVariables_17_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:1544:7: lv_inputVariables_17_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_inputVariables_17_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"inputVariables",
-                            								lv_inputVariables_17_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1561:5: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) ) )*
-                            loop39:
-                            do {
-                                int alt39=2;
-                                int LA39_0 = input.LA(1);
-
-                                if ( (LA39_0==RULE_SEPARATOR) ) {
-                                    alt39=1;
-                                }
-
-
-                                switch (alt39) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1562:6: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_18=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_18, grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1566:6: ( (lv_inputVariables_19_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:1567:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1567:7: (lv_inputVariables_19_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:1568:8: lv_inputVariables_19_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_inputVariables_19_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"inputVariables",
-                            	    									lv_inputVariables_19_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop39;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_20=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
-
-                    				newLeafNode(this_LIST_CLOSED_20, grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_5());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:1592:3: (otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED )?
-            int alt44=2;
-            int LA44_0 = input.LA(1);
-
-            if ( (LA44_0==17) ) {
-                alt44=1;
-            }
-            switch (alt44) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1593:4: otherlv_21= 'with' otherlv_22= 'outputVariables' this_ASSOCIATION_23= RULE_ASSOCIATION this_LIST_OPEN_24= RULE_LIST_OPEN ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_28= RULE_LIST_CLOSED
-                    {
-                    otherlv_21=(Token)match(input,17,FOLLOW_27); 
-
-                    				newLeafNode(otherlv_21, grammarAccess.getScriptTaskFlowElementAccess().getWithKeyword_6_0());
-                    			
-                    otherlv_22=(Token)match(input,31,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_22, grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesKeyword_6_1());
-                    			
-                    this_ASSOCIATION_23=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_23, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2());
-                    			
-                    this_LIST_OPEN_24=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_24, grammarAccess.getScriptTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3());
-                    			
-                    // InternalTestgeneratorDSL.g:1609:4: ( ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )* )?
-                    int alt43=2;
-                    int LA43_0 = input.LA(1);
-
-                    if ( (LA43_0==RULE_ID) ) {
-                        alt43=1;
-                    }
-                    switch (alt43) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1610:5: ( (lv_outputVariables_25_0= ruleVariableReference ) ) (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1610:5: ( (lv_outputVariables_25_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:1611:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:1611:6: (lv_outputVariables_25_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:1612:7: lv_outputVariables_25_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_outputVariables_25_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"outputVariables",
-                            								lv_outputVariables_25_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1629:5: (this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) ) )*
-                            loop42:
-                            do {
-                                int alt42=2;
-                                int LA42_0 = input.LA(1);
-
-                                if ( (LA42_0==RULE_SEPARATOR) ) {
-                                    alt42=1;
-                                }
-
-
-                                switch (alt42) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1630:6: this_SEPARATOR_26= RULE_SEPARATOR ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_26=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_26, grammarAccess.getScriptTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1634:6: ( (lv_outputVariables_27_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:1635:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1635:7: (lv_outputVariables_27_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:1636:8: lv_outputVariables_27_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getScriptTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_outputVariables_27_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getScriptTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"outputVariables",
-                            	    									lv_outputVariables_27_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop42;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_28=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_28); 
-
-                    				newLeafNode(this_LIST_CLOSED_28, grammarAccess.getScriptTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:1660:3: (otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) ) )?
-            int alt45=2;
-            int LA45_0 = input.LA(1);
-
-            if ( (LA45_0==32) ) {
-                alt45=1;
-            }
-            switch (alt45) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1661:4: otherlv_29= 'and' otherlv_30= 'label' this_ASSOCIATION_31= RULE_ASSOCIATION ( (lv_label_32_0= RULE_STRING ) )
-                    {
-                    otherlv_29=(Token)match(input,32,FOLLOW_29); 
-
-                    				newLeafNode(otherlv_29, grammarAccess.getScriptTaskFlowElementAccess().getAndKeyword_7_0());
-                    			
-                    otherlv_30=(Token)match(input,33,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_30, grammarAccess.getScriptTaskFlowElementAccess().getLabelKeyword_7_1());
-                    			
-                    this_ASSOCIATION_31=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
-
-                    				newLeafNode(this_ASSOCIATION_31, grammarAccess.getScriptTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2());
-                    			
-                    // InternalTestgeneratorDSL.g:1673:4: ( (lv_label_32_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:1674:5: (lv_label_32_0= RULE_STRING )
-                    {
-                    // InternalTestgeneratorDSL.g:1674:5: (lv_label_32_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:1675:6: lv_label_32_0= RULE_STRING
-                    {
-                    lv_label_32_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
-
-                    						newLeafNode(lv_label_32_0, grammarAccess.getScriptTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_7_3_0());
-                    					
-
-                    						if (current==null) {
-                    							current = createModelElement(grammarAccess.getScriptTaskFlowElementRule());
-                    						}
-                    						setWithLastConsumed(
-                    							current,
-                    							"label",
-                    							lv_label_32_0,
-                    							"org.eclipse.xtext.common.Terminals.STRING");
-                    					
-
-                    }
-
-
-                    }
-
-
-                    }
-                    break;
-
-            }
-
-            this_DECLARATION_FINISHED_33=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-
-            			newLeafNode(this_DECLARATION_FINISHED_33, grammarAccess.getScriptTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_8());
-            		
-
-            }
-
-
-            }
-
-
-            	leaveRule();
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "ruleScriptTaskFlowElement"
-
-
-    // $ANTLR start "entryRuleServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1700:1: entryRuleServiceTaskFlowElement returns [EObject current=null] : iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF ;
-    public final EObject entryRuleServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        EObject iv_ruleServiceTaskFlowElement = null;
-
-
-        try {
-            // InternalTestgeneratorDSL.g:1700:63: (iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:1701:2: iv_ruleServiceTaskFlowElement= ruleServiceTaskFlowElement EOF
-            {
-             newCompositeNode(grammarAccess.getServiceTaskFlowElementRule()); 
-            pushFollow(FOLLOW_1);
-            iv_ruleServiceTaskFlowElement=ruleServiceTaskFlowElement();
-
-            state._fsp--;
-
-             current =iv_ruleServiceTaskFlowElement; 
-            match(input,EOF,FOLLOW_2); 
-
-            }
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "entryRuleServiceTaskFlowElement"
-
-
-    // $ANTLR start "ruleServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1707:1: ruleServiceTaskFlowElement returns [EObject current=null] : (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement ) ;
-    public final EObject ruleServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        EObject this_DelegateServiceTaskFlowElement_0 = null;
-
-        EObject this_ExternalServiceTaskFlowElement_1 = null;
-
-
-
-        	enterRule();
-
-        try {
-            // InternalTestgeneratorDSL.g:1713:2: ( (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement ) )
-            // InternalTestgeneratorDSL.g:1714:2: (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement )
-            {
-            // InternalTestgeneratorDSL.g:1714:2: (this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement | this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement )
-            int alt46=2;
-            int LA46_0 = input.LA(1);
-
-            if ( (LA46_0==23) ) {
-                int LA46_1 = input.LA(2);
-
-                if ( (LA46_1==RULE_ID) ) {
-                    int LA46_2 = input.LA(3);
-
-                    if ( (LA46_2==RULE_ASSOCIATION) ) {
-                        int LA46_3 = input.LA(4);
-
-                        if ( (LA46_3==36) ) {
-                            int LA46_4 = input.LA(5);
-
-                            if ( (LA46_4==17) ) {
-                                int LA46_5 = input.LA(6);
-
-                                if ( (LA46_5==38) ) {
-                                    alt46=2;
-                                }
-                                else if ( (LA46_5==37) ) {
-                                    alt46=1;
-                                }
-                                else {
-                                    NoViableAltException nvae =
-                                        new NoViableAltException("", 46, 5, input);
-
-                                    throw nvae;
-                                }
-                            }
-                            else {
-                                NoViableAltException nvae =
-                                    new NoViableAltException("", 46, 4, input);
-
-                                throw nvae;
-                            }
-                        }
-                        else {
-                            NoViableAltException nvae =
-                                new NoViableAltException("", 46, 3, input);
-
-                            throw nvae;
-                        }
-                    }
-                    else {
-                        NoViableAltException nvae =
-                            new NoViableAltException("", 46, 2, input);
-
-                        throw nvae;
-                    }
-                }
-                else {
-                    NoViableAltException nvae =
-                        new NoViableAltException("", 46, 1, input);
-
-                    throw nvae;
-                }
-            }
-            else {
-                NoViableAltException nvae =
-                    new NoViableAltException("", 46, 0, input);
-
-                throw nvae;
-            }
-            switch (alt46) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1715:3: this_DelegateServiceTaskFlowElement_0= ruleDelegateServiceTaskFlowElement
-                    {
-
-                    			newCompositeNode(grammarAccess.getServiceTaskFlowElementAccess().getDelegateServiceTaskFlowElementParserRuleCall_0());
-                    		
-                    pushFollow(FOLLOW_2);
-                    this_DelegateServiceTaskFlowElement_0=ruleDelegateServiceTaskFlowElement();
-
-                    state._fsp--;
-
-
-                    			current = this_DelegateServiceTaskFlowElement_0;
-                    			afterParserOrEnumRuleCall();
-                    		
-
-                    }
-                    break;
-                case 2 :
-                    // InternalTestgeneratorDSL.g:1724:3: this_ExternalServiceTaskFlowElement_1= ruleExternalServiceTaskFlowElement
-                    {
-
-                    			newCompositeNode(grammarAccess.getServiceTaskFlowElementAccess().getExternalServiceTaskFlowElementParserRuleCall_1());
-                    		
-                    pushFollow(FOLLOW_2);
-                    this_ExternalServiceTaskFlowElement_1=ruleExternalServiceTaskFlowElement();
-
-                    state._fsp--;
-
-
-                    			current = this_ExternalServiceTaskFlowElement_1;
-                    			afterParserOrEnumRuleCall();
-                    		
-
-                    }
-                    break;
-
-            }
-
-
-            }
-
-
-            	leaveRule();
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "ruleServiceTaskFlowElement"
-
-
-    // $ANTLR start "entryRuleDelegateServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1736:1: entryRuleDelegateServiceTaskFlowElement returns [EObject current=null] : iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF ;
-    public final EObject entryRuleDelegateServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        EObject iv_ruleDelegateServiceTaskFlowElement = null;
-
-
-        try {
-            // InternalTestgeneratorDSL.g:1736:71: (iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:1737:2: iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF
-            {
-             newCompositeNode(grammarAccess.getDelegateServiceTaskFlowElementRule()); 
-            pushFollow(FOLLOW_1);
-            iv_ruleDelegateServiceTaskFlowElement=ruleDelegateServiceTaskFlowElement();
-
-            state._fsp--;
-
-             current =iv_ruleDelegateServiceTaskFlowElement; 
-            match(input,EOF,FOLLOW_2); 
-
-            }
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "entryRuleDelegateServiceTaskFlowElement"
-
-
-    // $ANTLR start "ruleDelegateServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1743:1: ruleDelegateServiceTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) ;
-    public final EObject ruleDelegateServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        Token otherlv_0=null;
-        Token lv_name_1_0=null;
-        Token this_ASSOCIATION_2=null;
-        Token otherlv_3=null;
-        Token otherlv_4=null;
-        Token otherlv_5=null;
-        Token this_ASSOCIATION_6=null;
-        Token lv_delegate_7_0=null;
-        Token otherlv_8=null;
-        Token otherlv_9=null;
-        Token this_ASSOCIATION_10=null;
-        Token lv_label_11_0=null;
-        Token this_DECLARATION_FINISHED_12=null;
-
-
-        	enterRule();
-
-        try {
-            // InternalTestgeneratorDSL.g:1749:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:1750:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:1750:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:1751:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED
-            {
-            otherlv_0=(Token)match(input,23,FOLLOW_4); 
-
-            			newLeafNode(otherlv_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0());
-            		
-            // InternalTestgeneratorDSL.g:1755:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:1756:4: (lv_name_1_0= RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:1756:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:1757:5: lv_name_1_0= RULE_ID
-            {
-            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
-
-            					newLeafNode(lv_name_1_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
-            				
-
-            					if (current==null) {
-            						current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
-            					}
-            					setWithLastConsumed(
-            						current,
-            						"name",
-            						lv_name_1_0,
-            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
-            				
-
-            }
-
-
-            }
-
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_32); 
-
-            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
-            		
-            otherlv_3=(Token)match(input,36,FOLLOW_5); 
-
-            			newLeafNode(otherlv_3, grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3());
-            		
-            otherlv_4=(Token)match(input,17,FOLLOW_33); 
-
-            			newLeafNode(otherlv_4, grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4());
-            		
-            otherlv_5=(Token)match(input,37,FOLLOW_12); 
-
-            			newLeafNode(otherlv_5, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5());
-            		
-            this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
-
-            			newLeafNode(this_ASSOCIATION_6, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6());
-            		
-            // InternalTestgeneratorDSL.g:1793:3: ( (lv_delegate_7_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:1794:4: (lv_delegate_7_0= RULE_STRING )
-            {
-            // InternalTestgeneratorDSL.g:1794:4: (lv_delegate_7_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:1795:5: lv_delegate_7_0= RULE_STRING
-            {
-            lv_delegate_7_0=(Token)match(input,RULE_STRING,FOLLOW_28); 
-
-            					newLeafNode(lv_delegate_7_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0());
-            				
-
-            					if (current==null) {
-            						current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
-            					}
-            					setWithLastConsumed(
-            						current,
-            						"delegate",
-            						lv_delegate_7_0,
-            						"org.eclipse.xtext.common.Terminals.STRING");
-            				
-
-            }
-
-
-            }
-
-            // InternalTestgeneratorDSL.g:1811:3: (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )?
-            int alt47=2;
-            int LA47_0 = input.LA(1);
-
-            if ( (LA47_0==32) ) {
-                alt47=1;
-            }
-            switch (alt47) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1812:4: otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) )
-                    {
-                    otherlv_8=(Token)match(input,32,FOLLOW_29); 
-
-                    				newLeafNode(otherlv_8, grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0());
-                    			
-                    otherlv_9=(Token)match(input,33,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_9, grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1());
-                    			
-                    this_ASSOCIATION_10=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
-
-                    				newLeafNode(this_ASSOCIATION_10, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2());
-                    			
-                    // InternalTestgeneratorDSL.g:1824:4: ( (lv_label_11_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:1825:5: (lv_label_11_0= RULE_STRING )
-                    {
-                    // InternalTestgeneratorDSL.g:1825:5: (lv_label_11_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:1826:6: lv_label_11_0= RULE_STRING
-                    {
-                    lv_label_11_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
-
-                    						newLeafNode(lv_label_11_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0());
-                    					
-
-                    						if (current==null) {
-                    							current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
-                    						}
-                    						setWithLastConsumed(
-                    							current,
-                    							"label",
-                    							lv_label_11_0,
-                    							"org.eclipse.xtext.common.Terminals.STRING");
-                    					
-
-                    }
-
-
-                    }
-
-
-                    }
-                    break;
-
-            }
-
-            this_DECLARATION_FINISHED_12=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
-
-            			newLeafNode(this_DECLARATION_FINISHED_12, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9());
-            		
-
-            }
-
-
-            }
-
-
-            	leaveRule();
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "ruleDelegateServiceTaskFlowElement"
-
-
-    // $ANTLR start "entryRuleExternalServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1851:1: entryRuleExternalServiceTaskFlowElement returns [EObject current=null] : iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF ;
-    public final EObject entryRuleExternalServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        EObject iv_ruleExternalServiceTaskFlowElement = null;
-
-
-        try {
-            // InternalTestgeneratorDSL.g:1851:71: (iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:1852:2: iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF
-            {
-             newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementRule()); 
-            pushFollow(FOLLOW_1);
-            iv_ruleExternalServiceTaskFlowElement=ruleExternalServiceTaskFlowElement();
-
-            state._fsp--;
-
-             current =iv_ruleExternalServiceTaskFlowElement; 
-            match(input,EOF,FOLLOW_2); 
-
-            }
-
-        }
-
-            catch (RecognitionException re) {
-                recover(input,re);
-                appendSkippedTokens();
-            }
-        finally {
-        }
-        return current;
-    }
-    // $ANTLR end "entryRuleExternalServiceTaskFlowElement"
-
-
-    // $ANTLR start "ruleExternalServiceTaskFlowElement"
-    // InternalTestgeneratorDSL.g:1858:1: ruleExternalServiceTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED ) ;
-    public final EObject ruleExternalServiceTaskFlowElement() throws RecognitionException {
-        EObject current = null;
-
-        Token otherlv_0=null;
-        Token lv_name_1_0=null;
-        Token this_ASSOCIATION_2=null;
-        Token otherlv_3=null;
-        Token otherlv_4=null;
-        Token otherlv_5=null;
-        Token this_ASSOCIATION_6=null;
-        Token otherlv_8=null;
-        Token otherlv_9=null;
-        Token otherlv_10=null;
-        Token this_ASSOCIATION_11=null;
-        Token this_LIST_OPEN_12=null;
-        Token this_SEPARATOR_14=null;
-        Token this_LIST_CLOSED_16=null;
-        Token otherlv_17=null;
-        Token otherlv_18=null;
-        Token this_ASSOCIATION_19=null;
-        Token this_LIST_OPEN_20=null;
-        Token this_SEPARATOR_22=null;
-        Token this_LIST_CLOSED_24=null;
-        Token otherlv_25=null;
-        Token otherlv_26=null;
-        Token this_ASSOCIATION_27=null;
-        Token this_LIST_OPEN_28=null;
-        Token this_SEPARATOR_30=null;
-        Token this_LIST_CLOSED_32=null;
-        Token otherlv_33=null;
-        Token otherlv_34=null;
-        Token this_ASSOCIATION_35=null;
-        Token lv_label_36_0=null;
-        Token this_DECLARATION_FINISHED_37=null;
-        EObject lv_externalTopic_7_0 = null;
-
-        EObject lv_hardcodedInputs_13_0 = null;
-
-        EObject lv_hardcodedInputs_15_0 = null;
-
-        EObject lv_inputVariables_21_0 = null;
-
-        EObject lv_inputVariables_23_0 = null;
-
-        EObject lv_outputVariables_29_0 = null;
-
-        EObject lv_outputVariables_31_0 = null;
-
-
-
-        	enterRule();
-
-        try {
-            // InternalTestgeneratorDSL.g:1864:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:1865:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED )
-            {
-            // InternalTestgeneratorDSL.g:1865:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:1866:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED
-            {
-            otherlv_0=(Token)match(input,23,FOLLOW_4); 
-
-            			newLeafNode(otherlv_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0());
-            		
-            // InternalTestgeneratorDSL.g:1870:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:1871:4: (lv_name_1_0= RULE_ID )
-            {
-            // InternalTestgeneratorDSL.g:1871:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:1872:5: lv_name_1_0= RULE_ID
-            {
-            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
-
-            					newLeafNode(lv_name_1_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
-            				
-
-            					if (current==null) {
-            						current = createModelElement(grammarAccess.getExternalServiceTaskFlowElementRule());
-            					}
-            					setWithLastConsumed(
-            						current,
-            						"name",
-            						lv_name_1_0,
-            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
-            				
-
-            }
-
-
-            }
-
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_32); 
-
-            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
-            		
-            otherlv_3=(Token)match(input,36,FOLLOW_5); 
-
-            			newLeafNode(otherlv_3, grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3());
-            		
-            otherlv_4=(Token)match(input,17,FOLLOW_34); 
-
-            			newLeafNode(otherlv_4, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4());
-            		
-            otherlv_5=(Token)match(input,38,FOLLOW_12); 
-
-            			newLeafNode(otherlv_5, grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5());
-            		
-            this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_4); 
-
-            			newLeafNode(this_ASSOCIATION_6, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6());
-            		
-            // InternalTestgeneratorDSL.g:1908:3: ( (lv_externalTopic_7_0= ruleExternalTopicReference ) )
-            // InternalTestgeneratorDSL.g:1909:4: (lv_externalTopic_7_0= ruleExternalTopicReference )
-            {
-            // InternalTestgeneratorDSL.g:1909:4: (lv_externalTopic_7_0= ruleExternalTopicReference )
-            // InternalTestgeneratorDSL.g:1910:5: lv_externalTopic_7_0= ruleExternalTopicReference
-            {
-
-            					newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0());
-            				
-            pushFollow(FOLLOW_25);
-            lv_externalTopic_7_0=ruleExternalTopicReference();
-
-            state._fsp--;
-
-
-            					if (current==null) {
-            						current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-            					}
-            					set(
-            						current,
-            						"externalTopic",
-            						lv_externalTopic_7_0,
-            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ExternalTopicReference");
-            					afterParserOrEnumRuleCall();
-            				
-
-            }
-
-
-            }
-
-            // InternalTestgeneratorDSL.g:1927:3: (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )?
-            int alt50=2;
-            int LA50_0 = input.LA(1);
-
-            if ( (LA50_0==17) ) {
-                int LA50_1 = input.LA(2);
-
-                if ( (LA50_1==25) ) {
-                    alt50=1;
-                }
-            }
-            switch (alt50) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:1928:4: otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED
-                    {
-                    otherlv_8=(Token)match(input,17,FOLLOW_19); 
-
-                    				newLeafNode(otherlv_8, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0());
-                    			
-                    otherlv_9=(Token)match(input,25,FOLLOW_20); 
-
-                    				newLeafNode(otherlv_9, grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1());
-                    			
-                    otherlv_10=(Token)match(input,26,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_10, grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2());
-                    			
-                    this_ASSOCIATION_11=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_11, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3());
-                    			
-                    this_LIST_OPEN_12=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_12, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4());
-                    			
-                    // InternalTestgeneratorDSL.g:1948:4: ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )?
-                    int alt49=2;
-                    int LA49_0 = input.LA(1);
-
-                    if ( (LA49_0==RULE_ID) ) {
-                        alt49=1;
-                    }
-                    switch (alt49) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:1949:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:1949:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:1950:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
-                            {
-                            // InternalTestgeneratorDSL.g:1950:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:1951:7: lv_hardcodedInputs_13_0= ruleVariableDeclaration
-                            {
-
-                            							newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_hardcodedInputs_13_0=ruleVariableDeclaration();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"hardcodedInputs",
-                            								lv_hardcodedInputs_13_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:1968:5: (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
-                            loop48:
-                            do {
-                                int alt48=2;
-                                int LA48_0 = input.LA(1);
-
-                                if ( (LA48_0==RULE_SEPARATOR) ) {
-                                    alt48=1;
-                                }
-
-
-                                switch (alt48) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:1969:6: this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
-                            	    {
-                            	    this_SEPARATOR_14=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_14, grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:1973:6: ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:1974:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:1974:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:1975:8: lv_hardcodedInputs_15_0= ruleVariableDeclaration
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_hardcodedInputs_15_0=ruleVariableDeclaration();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"hardcodedInputs",
-                            	    									lv_hardcodedInputs_15_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableDeclaration");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop48;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
-
-                    }
-
-                    this_LIST_CLOSED_16=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
-
-                    				newLeafNode(this_LIST_CLOSED_16, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6());
-                    			
-
-                    }
-                    break;
-
-            }
-
-            // InternalTestgeneratorDSL.g:1999:3: (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )?
-            int alt53=2;
-            int LA53_0 = input.LA(1);
-
-            if ( (LA53_0==17) ) {
-                int LA53_1 = input.LA(2);
-
-                if ( (LA53_1==30) ) {
-                    alt53=1;
-                }
-            }
-            switch (alt53) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:2000:4: otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED
-                    {
-                    otherlv_17=(Token)match(input,17,FOLLOW_26); 
-
-                    				newLeafNode(otherlv_17, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_9_0());
-                    			
-                    otherlv_18=(Token)match(input,30,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_18, grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesKeyword_9_1());
-                    			
-                    this_ASSOCIATION_19=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_19, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2());
-                    			
-                    this_LIST_OPEN_20=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_20, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_9_3());
-                    			
-                    // InternalTestgeneratorDSL.g:2016:4: ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )?
-                    int alt52=2;
-                    int LA52_0 = input.LA(1);
-
-                    if ( (LA52_0==RULE_ID) ) {
-                        alt52=1;
-                    }
-                    switch (alt52) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:2017:5: ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:2017:5: ( (lv_inputVariables_21_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:2018:6: (lv_inputVariables_21_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:2018:6: (lv_inputVariables_21_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:2019:7: lv_inputVariables_21_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_inputVariables_21_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"inputVariables",
-                            								lv_inputVariables_21_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
-
-                            }
-
-
-                            }
-
-                            // InternalTestgeneratorDSL.g:2036:5: (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )*
-                            loop51:
-                            do {
-                                int alt51=2;
-                                int LA51_0 = input.LA(1);
-
-                                if ( (LA51_0==RULE_SEPARATOR) ) {
-                                    alt51=1;
-                                }
-
-
-                                switch (alt51) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:2037:6: this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_22=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
-
-                            	    						newLeafNode(this_SEPARATOR_22, grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_9_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:2041:6: ( (lv_inputVariables_23_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:2042:7: (lv_inputVariables_23_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:2042:7: (lv_inputVariables_23_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:2043:8: lv_inputVariables_23_0= ruleVariableReference
-                            	    {
-
-                            	    								newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_inputVariables_23_0=ruleVariableReference();
-
-                            	    state._fsp--;
-
-
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"inputVariables",
-                            	    									lv_inputVariables_23_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
-
-                            	    }
-
-
-                            	    }
-
-
-                            	    }
-                            	    break;
-
-                            	default :
-                            	    break loop51;
-                                }
-                            } while (true);
-
-
-                            }
-                            break;
+                    			newCompositeNode(grammarAccess.getServiceTaskFlowElementAccess().getExternalServiceTaskFlowElementParserRuleCall_1());
+                    		
+                    pushFollow(FOLLOW_2);
+                    this_ExternalServiceTaskFlowElement_1=ruleExternalServiceTaskFlowElement();
 
-                    }
+                    state._fsp--;
 
-                    this_LIST_CLOSED_24=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
 
-                    				newLeafNode(this_LIST_CLOSED_24, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_9_5());
-                    			
+                    			current = this_ExternalServiceTaskFlowElement_1;
+                    			afterParserOrEnumRuleCall();
+                    		
 
                     }
                     break;
 
             }
 
-            // InternalTestgeneratorDSL.g:2067:3: (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )?
-            int alt56=2;
-            int LA56_0 = input.LA(1);
 
-            if ( (LA56_0==17) ) {
-                alt56=1;
             }
-            switch (alt56) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:2068:4: otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED
-                    {
-                    otherlv_25=(Token)match(input,17,FOLLOW_27); 
 
-                    				newLeafNode(otherlv_25, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_10_0());
-                    			
-                    otherlv_26=(Token)match(input,31,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_26, grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesKeyword_10_1());
-                    			
-                    this_ASSOCIATION_27=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+            	leaveRule();
 
-                    				newLeafNode(this_ASSOCIATION_27, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_10_2());
-                    			
-                    this_LIST_OPEN_28=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+        }
 
-                    				newLeafNode(this_LIST_OPEN_28, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_10_3());
-                    			
-                    // InternalTestgeneratorDSL.g:2084:4: ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )?
-                    int alt55=2;
-                    int LA55_0 = input.LA(1);
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
+            }
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "ruleServiceTaskFlowElement"
 
-                    if ( (LA55_0==RULE_ID) ) {
-                        alt55=1;
-                    }
-                    switch (alt55) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:2085:5: ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:2085:5: ( (lv_outputVariables_29_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:2086:6: (lv_outputVariables_29_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:2086:6: (lv_outputVariables_29_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:2087:7: lv_outputVariables_29_0= ruleVariableReference
-                            {
 
-                            							newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_outputVariables_29_0=ruleVariableReference();
+    // $ANTLR start "entryRuleDelegateServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1108:1: entryRuleDelegateServiceTaskFlowElement returns [EObject current=null] : iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF ;
+    public final EObject entryRuleDelegateServiceTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                            state._fsp--;
+        EObject iv_ruleDelegateServiceTaskFlowElement = null;
 
 
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"outputVariables",
-                            								lv_outputVariables_29_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
+        try {
+            // InternalTestgeneratorDSL.g:1108:71: (iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1109:2: iv_ruleDelegateServiceTaskFlowElement= ruleDelegateServiceTaskFlowElement EOF
+            {
+             newCompositeNode(grammarAccess.getDelegateServiceTaskFlowElementRule()); 
+            pushFollow(FOLLOW_1);
+            iv_ruleDelegateServiceTaskFlowElement=ruleDelegateServiceTaskFlowElement();
 
-                            }
+            state._fsp--;
 
+             current =iv_ruleDelegateServiceTaskFlowElement; 
+            match(input,EOF,FOLLOW_2); 
 
-                            }
+            }
 
-                            // InternalTestgeneratorDSL.g:2104:5: (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )*
-                            loop54:
-                            do {
-                                int alt54=2;
-                                int LA54_0 = input.LA(1);
+        }
 
-                                if ( (LA54_0==RULE_SEPARATOR) ) {
-                                    alt54=1;
-                                }
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
+            }
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "entryRuleDelegateServiceTaskFlowElement"
 
 
-                                switch (alt54) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:2105:6: this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_30=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+    // $ANTLR start "ruleDelegateServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1115:1: ruleDelegateServiceTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) ;
+    public final EObject ruleDelegateServiceTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                            	    						newLeafNode(this_SEPARATOR_30, grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_10_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:2109:6: ( (lv_outputVariables_31_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:2110:7: (lv_outputVariables_31_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:2110:7: (lv_outputVariables_31_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:2111:8: lv_outputVariables_31_0= ruleVariableReference
-                            	    {
+        Token otherlv_0=null;
+        Token lv_name_1_0=null;
+        Token this_ASSOCIATION_2=null;
+        Token otherlv_3=null;
+        Token otherlv_4=null;
+        Token otherlv_5=null;
+        Token this_ASSOCIATION_6=null;
+        Token lv_delegate_7_0=null;
+        Token otherlv_8=null;
+        Token otherlv_9=null;
+        Token this_ASSOCIATION_10=null;
+        Token lv_label_11_0=null;
+        Token this_DECLARATION_FINISHED_12=null;
 
-                            	    								newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_outputVariables_31_0=ruleVariableReference();
 
-                            	    state._fsp--;
+        	enterRule();
 
+        try {
+            // InternalTestgeneratorDSL.g:1121:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1122:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
+            {
+            // InternalTestgeneratorDSL.g:1122:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1123:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'delegate' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_delegate_7_0= RULE_STRING ) ) (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED
+            {
+            otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"outputVariables",
-                            	    									lv_outputVariables_31_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
+            			newLeafNode(otherlv_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getFlowElementKeyword_0());
+            		
+            // InternalTestgeneratorDSL.g:1127:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1128:4: (lv_name_1_0= RULE_ID )
+            {
+            // InternalTestgeneratorDSL.g:1128:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1129:5: lv_name_1_0= RULE_ID
+            {
+            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
-                            	    }
+            					newLeafNode(lv_name_1_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
+            				
+
+            					if (current==null) {
+            						current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
+            					}
+            					setWithLastConsumed(
+            						current,
+            						"name",
+            						lv_name_1_0,
+            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
+            				
 
+            }
 
-                            	    }
 
+            }
 
-                            	    }
-                            	    break;
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_28); 
 
-                            	default :
-                            	    break loop54;
-                                }
-                            } while (true);
+            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
+            		
+            otherlv_3=(Token)match(input,32,FOLLOW_5); 
 
+            			newLeafNode(otherlv_3, grammarAccess.getDelegateServiceTaskFlowElementAccess().getServiceTaskKeyword_3());
+            		
+            otherlv_4=(Token)match(input,17,FOLLOW_29); 
 
-                            }
-                            break;
+            			newLeafNode(otherlv_4, grammarAccess.getDelegateServiceTaskFlowElementAccess().getWithKeyword_4());
+            		
+            otherlv_5=(Token)match(input,33,FOLLOW_12); 
 
-                    }
+            			newLeafNode(otherlv_5, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateKeyword_5());
+            		
+            this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    this_LIST_CLOSED_32=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_28); 
+            			newLeafNode(this_ASSOCIATION_6, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6());
+            		
+            // InternalTestgeneratorDSL.g:1165:3: ( (lv_delegate_7_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:1166:4: (lv_delegate_7_0= RULE_STRING )
+            {
+            // InternalTestgeneratorDSL.g:1166:4: (lv_delegate_7_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:1167:5: lv_delegate_7_0= RULE_STRING
+            {
+            lv_delegate_7_0=(Token)match(input,RULE_STRING,FOLLOW_24); 
 
-                    				newLeafNode(this_LIST_CLOSED_32, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_10_5());
-                    			
+            					newLeafNode(lv_delegate_7_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDelegateSTRINGTerminalRuleCall_7_0());
+            				
 
-                    }
-                    break;
+            					if (current==null) {
+            						current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
+            					}
+            					setWithLastConsumed(
+            						current,
+            						"delegate",
+            						lv_delegate_7_0,
+            						"org.eclipse.xtext.common.Terminals.STRING");
+            				
 
             }
 
-            // InternalTestgeneratorDSL.g:2135:3: (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )?
-            int alt57=2;
-            int LA57_0 = input.LA(1);
 
-            if ( (LA57_0==32) ) {
-                alt57=1;
             }
-            switch (alt57) {
+
+            // InternalTestgeneratorDSL.g:1183:3: (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )?
+            int alt20=2;
+            int LA20_0 = input.LA(1);
+
+            if ( (LA20_0==28) ) {
+                alt20=1;
+            }
+            switch (alt20) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2136:4: otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1184:4: otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) )
                     {
-                    otherlv_33=(Token)match(input,32,FOLLOW_29); 
+                    otherlv_8=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_33, grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_11_0());
+                    				newLeafNode(otherlv_8, grammarAccess.getDelegateServiceTaskFlowElementAccess().getAndKeyword_8_0());
                     			
-                    otherlv_34=(Token)match(input,33,FOLLOW_12); 
+                    otherlv_9=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_34, grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_11_1());
+                    				newLeafNode(otherlv_9, grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelKeyword_8_1());
                     			
-                    this_ASSOCIATION_35=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
+                    this_ASSOCIATION_10=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(this_ASSOCIATION_35, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_11_2());
+                    				newLeafNode(this_ASSOCIATION_10, grammarAccess.getDelegateServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2());
                     			
-                    // InternalTestgeneratorDSL.g:2148:4: ( (lv_label_36_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:2149:5: (lv_label_36_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1196:4: ( (lv_label_11_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1197:5: (lv_label_11_0= RULE_STRING )
                     {
-                    // InternalTestgeneratorDSL.g:2149:5: (lv_label_36_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:2150:6: lv_label_36_0= RULE_STRING
+                    // InternalTestgeneratorDSL.g:1197:5: (lv_label_11_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1198:6: lv_label_11_0= RULE_STRING
                     {
-                    lv_label_36_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
+                    lv_label_11_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                    						newLeafNode(lv_label_36_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_11_3_0());
+                    						newLeafNode(lv_label_11_0, grammarAccess.getDelegateServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0());
                     					
 
                     						if (current==null) {
-                    							current = createModelElement(grammarAccess.getExternalServiceTaskFlowElementRule());
+                    							current = createModelElement(grammarAccess.getDelegateServiceTaskFlowElementRule());
                     						}
                     						setWithLastConsumed(
                     							current,
                     							"label",
-                    							lv_label_36_0,
+                    							lv_label_11_0,
                     							"org.eclipse.xtext.common.Terminals.STRING");
                     					
 
@@ -5008,9 +2870,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_DECLARATION_FINISHED_37=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+            this_DECLARATION_FINISHED_12=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-            			newLeafNode(this_DECLARATION_FINISHED_37, grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_12());
+            			newLeafNode(this_DECLARATION_FINISHED_12, grammarAccess.getDelegateServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9());
             		
 
             }
@@ -5031,28 +2893,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         }
         return current;
     }
-    // $ANTLR end "ruleExternalServiceTaskFlowElement"
+    // $ANTLR end "ruleDelegateServiceTaskFlowElement"
 
 
-    // $ANTLR start "entryRuleBusinessRuleTaskFlowElement"
-    // InternalTestgeneratorDSL.g:2175:1: entryRuleBusinessRuleTaskFlowElement returns [EObject current=null] : iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF ;
-    public final EObject entryRuleBusinessRuleTaskFlowElement() throws RecognitionException {
+    // $ANTLR start "entryRuleExternalServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1223:1: entryRuleExternalServiceTaskFlowElement returns [EObject current=null] : iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF ;
+    public final EObject entryRuleExternalServiceTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
-        EObject iv_ruleBusinessRuleTaskFlowElement = null;
+        EObject iv_ruleExternalServiceTaskFlowElement = null;
 
 
         try {
-            // InternalTestgeneratorDSL.g:2175:68: (iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF )
-            // InternalTestgeneratorDSL.g:2176:2: iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF
+            // InternalTestgeneratorDSL.g:1223:71: (iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1224:2: iv_ruleExternalServiceTaskFlowElement= ruleExternalServiceTaskFlowElement EOF
             {
-             newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementRule()); 
+             newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementRule()); 
             pushFollow(FOLLOW_1);
-            iv_ruleBusinessRuleTaskFlowElement=ruleBusinessRuleTaskFlowElement();
+            iv_ruleExternalServiceTaskFlowElement=ruleExternalServiceTaskFlowElement();
 
             state._fsp--;
 
-             current =iv_ruleBusinessRuleTaskFlowElement; 
+             current =iv_ruleExternalServiceTaskFlowElement; 
             match(input,EOF,FOLLOW_2); 
 
             }
@@ -5067,12 +2929,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         }
         return current;
     }
-    // $ANTLR end "entryRuleBusinessRuleTaskFlowElement"
+    // $ANTLR end "entryRuleExternalServiceTaskFlowElement"
 
 
-    // $ANTLR start "ruleBusinessRuleTaskFlowElement"
-    // InternalTestgeneratorDSL.g:2182:1: ruleBusinessRuleTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED ) ;
-    public final EObject ruleBusinessRuleTaskFlowElement() throws RecognitionException {
+    // $ANTLR start "ruleExternalServiceTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1230:1: ruleExternalServiceTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) ;
+    public final EObject ruleExternalServiceTaskFlowElement() throws RecognitionException {
         EObject current = null;
 
         Token otherlv_0=null;
@@ -5082,7 +2944,6 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         Token otherlv_4=null;
         Token otherlv_5=null;
         Token this_ASSOCIATION_6=null;
-        Token lv_resultVariable_7_0=null;
         Token otherlv_8=null;
         Token otherlv_9=null;
         Token otherlv_10=null;
@@ -5093,60 +2954,42 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         Token otherlv_17=null;
         Token otherlv_18=null;
         Token this_ASSOCIATION_19=null;
-        Token this_LIST_OPEN_20=null;
-        Token this_SEPARATOR_22=null;
-        Token this_LIST_CLOSED_24=null;
-        Token otherlv_25=null;
-        Token otherlv_26=null;
-        Token this_ASSOCIATION_27=null;
-        Token this_LIST_OPEN_28=null;
-        Token this_SEPARATOR_30=null;
-        Token this_LIST_CLOSED_32=null;
-        Token otherlv_33=null;
-        Token otherlv_34=null;
-        Token this_ASSOCIATION_35=null;
-        Token lv_label_36_0=null;
-        Token this_DECLARATION_FINISHED_37=null;
+        Token lv_label_20_0=null;
+        Token this_DECLARATION_FINISHED_21=null;
+        EObject lv_externalTopic_7_0 = null;
+
         EObject lv_hardcodedInputs_13_0 = null;
 
         EObject lv_hardcodedInputs_15_0 = null;
 
-        EObject lv_inputVariables_21_0 = null;
-
-        EObject lv_inputVariables_23_0 = null;
-
-        EObject lv_outputVariables_29_0 = null;
-
-        EObject lv_outputVariables_31_0 = null;
-
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2188:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2189:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1236:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1237:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2189:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2190:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )? (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )? (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_37= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1237:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1238:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'ServiceTask' otherlv_4= 'with' otherlv_5= 'external' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_externalTopic_7_0= ruleExternalTopicReference ) ) (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )? (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
-            			newLeafNode(otherlv_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0());
+            			newLeafNode(otherlv_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2194:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2195:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1242:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1243:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2195:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2196:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1243:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1244:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
-            					newLeafNode(lv_name_1_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
+            					newLeafNode(lv_name_1_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
             				
 
             					if (current==null) {
-            						current = createModelElement(grammarAccess.getBusinessRuleTaskFlowElementRule());
+            						current = createModelElement(grammarAccess.getExternalServiceTaskFlowElementRule());
             					}
             					setWithLastConsumed(
             						current,
@@ -5160,127 +3003,107 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_35); 
-
-            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
-            		
-            otherlv_3=(Token)match(input,39,FOLLOW_25); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_28); 
 
-            			newLeafNode(otherlv_3, grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3());
+            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            // InternalTestgeneratorDSL.g:2220:3: (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )?
-            int alt58=2;
-            int LA58_0 = input.LA(1);
+            otherlv_3=(Token)match(input,32,FOLLOW_5); 
 
-            if ( (LA58_0==17) ) {
-                int LA58_1 = input.LA(2);
-
-                if ( (LA58_1==40) ) {
-                    alt58=1;
-                }
-            }
-            switch (alt58) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:2221:4: otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) )
-                    {
-                    otherlv_4=(Token)match(input,17,FOLLOW_36); 
-
-                    				newLeafNode(otherlv_4, grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0());
-                    			
-                    otherlv_5=(Token)match(input,40,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_5, grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1());
-                    			
-                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
-
-                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
-                    			
-                    // InternalTestgeneratorDSL.g:2233:4: ( (lv_resultVariable_7_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:2234:5: (lv_resultVariable_7_0= RULE_STRING )
-                    {
-                    // InternalTestgeneratorDSL.g:2234:5: (lv_resultVariable_7_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:2235:6: lv_resultVariable_7_0= RULE_STRING
-                    {
-                    lv_resultVariable_7_0=(Token)match(input,RULE_STRING,FOLLOW_25); 
-
-                    						newLeafNode(lv_resultVariable_7_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0());
-                    					
-
-                    						if (current==null) {
-                    							current = createModelElement(grammarAccess.getBusinessRuleTaskFlowElementRule());
-                    						}
-                    						setWithLastConsumed(
-                    							current,
-                    							"resultVariable",
-                    							lv_resultVariable_7_0,
-                    							"org.eclipse.xtext.common.Terminals.STRING");
-                    					
+            			newLeafNode(otherlv_3, grammarAccess.getExternalServiceTaskFlowElementAccess().getServiceTaskKeyword_3());
+            		
+            otherlv_4=(Token)match(input,17,FOLLOW_30); 
 
-                    }
+            			newLeafNode(otherlv_4, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_4());
+            		
+            otherlv_5=(Token)match(input,34,FOLLOW_12); 
+
+            			newLeafNode(otherlv_5, grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalKeyword_5());
+            		
+            this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_4); 
 
+            			newLeafNode(this_ASSOCIATION_6, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6());
+            		
+            // InternalTestgeneratorDSL.g:1280:3: ( (lv_externalTopic_7_0= ruleExternalTopicReference ) )
+            // InternalTestgeneratorDSL.g:1281:4: (lv_externalTopic_7_0= ruleExternalTopicReference )
+            {
+            // InternalTestgeneratorDSL.g:1281:4: (lv_externalTopic_7_0= ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:1282:5: lv_externalTopic_7_0= ruleExternalTopicReference
+            {
 
-                    }
+            					newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getExternalTopicExternalTopicReferenceParserRuleCall_7_0());
+            				
+            pushFollow(FOLLOW_23);
+            lv_externalTopic_7_0=ruleExternalTopicReference();
 
+            state._fsp--;
 
-                    }
-                    break;
+
+            					if (current==null) {
+            						current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
+            					}
+            					set(
+            						current,
+            						"externalTopic",
+            						lv_externalTopic_7_0,
+            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ExternalTopicReference");
+            					afterParserOrEnumRuleCall();
+            				
 
             }
 
-            // InternalTestgeneratorDSL.g:2252:3: (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )?
-            int alt61=2;
-            int LA61_0 = input.LA(1);
 
-            if ( (LA61_0==17) ) {
-                int LA61_1 = input.LA(2);
+            }
 
-                if ( (LA61_1==25) ) {
-                    alt61=1;
-                }
+            // InternalTestgeneratorDSL.g:1299:3: (otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED )?
+            int alt23=2;
+            int LA23_0 = input.LA(1);
+
+            if ( (LA23_0==17) ) {
+                alt23=1;
             }
-            switch (alt61) {
+            switch (alt23) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2253:4: otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:1300:4: otherlv_8= 'with' otherlv_9= 'hardcoded' otherlv_10= 'inputs' this_ASSOCIATION_11= RULE_ASSOCIATION this_LIST_OPEN_12= RULE_LIST_OPEN ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_16= RULE_LIST_CLOSED
                     {
-                    otherlv_8=(Token)match(input,17,FOLLOW_19); 
+                    otherlv_8=(Token)match(input,17,FOLLOW_31); 
 
-                    				newLeafNode(otherlv_8, grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_5_0());
+                    				newLeafNode(otherlv_8, grammarAccess.getExternalServiceTaskFlowElementAccess().getWithKeyword_8_0());
                     			
-                    otherlv_9=(Token)match(input,25,FOLLOW_20); 
+                    otherlv_9=(Token)match(input,35,FOLLOW_32); 
 
-                    				newLeafNode(otherlv_9, grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedKeyword_5_1());
+                    				newLeafNode(otherlv_9, grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedKeyword_8_1());
                     			
-                    otherlv_10=(Token)match(input,26,FOLLOW_12); 
+                    otherlv_10=(Token)match(input,36,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_10, grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputsKeyword_5_2());
+                    				newLeafNode(otherlv_10, grammarAccess.getExternalServiceTaskFlowElementAccess().getInputsKeyword_8_2());
                     			
                     this_ASSOCIATION_11=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
 
-                    				newLeafNode(this_ASSOCIATION_11, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_3());
+                    				newLeafNode(this_ASSOCIATION_11, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_3());
                     			
-                    this_LIST_OPEN_12=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_LIST_OPEN_12=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
-                    				newLeafNode(this_LIST_OPEN_12, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_5_4());
+                    				newLeafNode(this_LIST_OPEN_12, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_8_4());
                     			
-                    // InternalTestgeneratorDSL.g:2273:4: ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )?
-                    int alt60=2;
-                    int LA60_0 = input.LA(1);
+                    // InternalTestgeneratorDSL.g:1320:4: ( ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )* )?
+                    int alt22=2;
+                    int LA22_0 = input.LA(1);
 
-                    if ( (LA60_0==RULE_ID) ) {
-                        alt60=1;
+                    if ( (LA22_0==RULE_ID) ) {
+                        alt22=1;
                     }
-                    switch (alt60) {
+                    switch (alt22) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:2274:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
+                            // InternalTestgeneratorDSL.g:1321:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) ) (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
                             {
-                            // InternalTestgeneratorDSL.g:2274:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) )
-                            // InternalTestgeneratorDSL.g:2275:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
+                            // InternalTestgeneratorDSL.g:1321:5: ( (lv_hardcodedInputs_13_0= ruleVariableDeclaration ) )
+                            // InternalTestgeneratorDSL.g:1322:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
                             {
-                            // InternalTestgeneratorDSL.g:2275:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
-                            // InternalTestgeneratorDSL.g:2276:7: lv_hardcodedInputs_13_0= ruleVariableDeclaration
+                            // InternalTestgeneratorDSL.g:1322:6: (lv_hardcodedInputs_13_0= ruleVariableDeclaration )
+                            // InternalTestgeneratorDSL.g:1323:7: lv_hardcodedInputs_13_0= ruleVariableDeclaration
                             {
 
-                            							newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0());
+                            							newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_0_0());
                             						
                             pushFollow(FOLLOW_15);
                             lv_hardcodedInputs_13_0=ruleVariableDeclaration();
@@ -5289,7 +3112,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
                             							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
+                            								current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
                             							}
                             							add(
                             								current,
@@ -5304,33 +3127,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                             }
 
-                            // InternalTestgeneratorDSL.g:2293:5: (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
-                            loop59:
+                            // InternalTestgeneratorDSL.g:1340:5: (this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) ) )*
+                            loop21:
                             do {
-                                int alt59=2;
-                                int LA59_0 = input.LA(1);
+                                int alt21=2;
+                                int LA21_0 = input.LA(1);
 
-                                if ( (LA59_0==RULE_SEPARATOR) ) {
-                                    alt59=1;
+                                if ( (LA21_0==RULE_SEPARATOR) ) {
+                                    alt21=1;
                                 }
 
 
-                                switch (alt59) {
+                                switch (alt21) {
                             	case 1 :
-                            	    // InternalTestgeneratorDSL.g:2294:6: this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
+                            	    // InternalTestgeneratorDSL.g:1341:6: this_SEPARATOR_14= RULE_SEPARATOR ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
                             	    {
                             	    this_SEPARATOR_14=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
-                            	    						newLeafNode(this_SEPARATOR_14, grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_5_5_1_0());
+                            	    						newLeafNode(this_SEPARATOR_14, grammarAccess.getExternalServiceTaskFlowElementAccess().getSEPARATORTerminalRuleCall_8_5_1_0());
                             	    					
-                            	    // InternalTestgeneratorDSL.g:2298:6: ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
-                            	    // InternalTestgeneratorDSL.g:2299:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
+                            	    // InternalTestgeneratorDSL.g:1345:6: ( (lv_hardcodedInputs_15_0= ruleVariableDeclaration ) )
+                            	    // InternalTestgeneratorDSL.g:1346:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
                             	    {
-                            	    // InternalTestgeneratorDSL.g:2299:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
-                            	    // InternalTestgeneratorDSL.g:2300:8: lv_hardcodedInputs_15_0= ruleVariableDeclaration
+                            	    // InternalTestgeneratorDSL.g:1346:7: (lv_hardcodedInputs_15_0= ruleVariableDeclaration )
+                            	    // InternalTestgeneratorDSL.g:1347:8: lv_hardcodedInputs_15_0= ruleVariableDeclaration
                             	    {
 
-                            	    								newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0());
+                            	    								newCompositeNode(grammarAccess.getExternalServiceTaskFlowElementAccess().getHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0());
                             	    							
                             	    pushFollow(FOLLOW_15);
                             	    lv_hardcodedInputs_15_0=ruleVariableDeclaration();
@@ -5339,7 +3162,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
                             	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
+                            	    									current = createModelElementForParent(grammarAccess.getExternalServiceTaskFlowElementRule());
                             	    								}
                             	    								add(
                             	    									current,
@@ -5359,7 +3182,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    break;
 
                             	default :
-                            	    break loop59;
+                            	    break loop21;
                                 }
                             } while (true);
 
@@ -5369,9 +3192,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    this_LIST_CLOSED_16=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
+                    this_LIST_CLOSED_16=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_24); 
 
-                    				newLeafNode(this_LIST_CLOSED_16, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_5_6());
+                    				newLeafNode(this_LIST_CLOSED_16, grammarAccess.getExternalServiceTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_8_6());
                     			
 
                     }
@@ -5379,330 +3202,277 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:2324:3: (otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED )?
-            int alt64=2;
-            int LA64_0 = input.LA(1);
-
-            if ( (LA64_0==17) ) {
-                int LA64_1 = input.LA(2);
+            // InternalTestgeneratorDSL.g:1371:3: (otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) ) )?
+            int alt24=2;
+            int LA24_0 = input.LA(1);
 
-                if ( (LA64_1==30) ) {
-                    alt64=1;
-                }
+            if ( (LA24_0==28) ) {
+                alt24=1;
             }
-            switch (alt64) {
+            switch (alt24) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2325:4: otherlv_17= 'with' otherlv_18= 'inputVariables' this_ASSOCIATION_19= RULE_ASSOCIATION this_LIST_OPEN_20= RULE_LIST_OPEN ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_24= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:1372:4: otherlv_17= 'and' otherlv_18= 'label' this_ASSOCIATION_19= RULE_ASSOCIATION ( (lv_label_20_0= RULE_STRING ) )
                     {
-                    otherlv_17=(Token)match(input,17,FOLLOW_26); 
-
-                    				newLeafNode(otherlv_17, grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_6_0());
-                    			
-                    otherlv_18=(Token)match(input,30,FOLLOW_12); 
+                    otherlv_17=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_18, grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesKeyword_6_1());
+                    				newLeafNode(otherlv_17, grammarAccess.getExternalServiceTaskFlowElementAccess().getAndKeyword_9_0());
                     			
-                    this_ASSOCIATION_19=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
+                    otherlv_18=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(this_ASSOCIATION_19, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_6_2());
+                    				newLeafNode(otherlv_18, grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelKeyword_9_1());
                     			
-                    this_LIST_OPEN_20=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_ASSOCIATION_19=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(this_LIST_OPEN_20, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_6_3());
+                    				newLeafNode(this_ASSOCIATION_19, grammarAccess.getExternalServiceTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_9_2());
                     			
-                    // InternalTestgeneratorDSL.g:2341:4: ( ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )* )?
-                    int alt63=2;
-                    int LA63_0 = input.LA(1);
-
-                    if ( (LA63_0==RULE_ID) ) {
-                        alt63=1;
-                    }
-                    switch (alt63) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:2342:5: ( (lv_inputVariables_21_0= ruleVariableReference ) ) (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:2342:5: ( (lv_inputVariables_21_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:2343:6: (lv_inputVariables_21_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:2343:6: (lv_inputVariables_21_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:2344:7: lv_inputVariables_21_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_inputVariables_21_0=ruleVariableReference();
-
-                            state._fsp--;
-
-
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"inputVariables",
-                            								lv_inputVariables_21_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
+                    // InternalTestgeneratorDSL.g:1384:4: ( (lv_label_20_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1385:5: (lv_label_20_0= RULE_STRING )
+                    {
+                    // InternalTestgeneratorDSL.g:1385:5: (lv_label_20_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1386:6: lv_label_20_0= RULE_STRING
+                    {
+                    lv_label_20_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                            }
+                    						newLeafNode(lv_label_20_0, grammarAccess.getExternalServiceTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_9_3_0());
+                    					
 
+                    						if (current==null) {
+                    							current = createModelElement(grammarAccess.getExternalServiceTaskFlowElementRule());
+                    						}
+                    						setWithLastConsumed(
+                    							current,
+                    							"label",
+                    							lv_label_20_0,
+                    							"org.eclipse.xtext.common.Terminals.STRING");
+                    					
 
-                            }
+                    }
 
-                            // InternalTestgeneratorDSL.g:2361:5: (this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) ) )*
-                            loop62:
-                            do {
-                                int alt62=2;
-                                int LA62_0 = input.LA(1);
 
-                                if ( (LA62_0==RULE_SEPARATOR) ) {
-                                    alt62=1;
-                                }
+                    }
 
 
-                                switch (alt62) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:2362:6: this_SEPARATOR_22= RULE_SEPARATOR ( (lv_inputVariables_23_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_22=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+                    }
+                    break;
 
-                            	    						newLeafNode(this_SEPARATOR_22, grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_6_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:2366:6: ( (lv_inputVariables_23_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:2367:7: (lv_inputVariables_23_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:2367:7: (lv_inputVariables_23_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:2368:8: lv_inputVariables_23_0= ruleVariableReference
-                            	    {
+            }
 
-                            	    								newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_inputVariables_23_0=ruleVariableReference();
+            this_DECLARATION_FINISHED_21=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-                            	    state._fsp--;
+            			newLeafNode(this_DECLARATION_FINISHED_21, grammarAccess.getExternalServiceTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_10());
+            		
 
+            }
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"inputVariables",
-                            	    									lv_inputVariables_23_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
 
-                            	    }
+            }
 
 
-                            	    }
+            	leaveRule();
 
+        }
 
-                            	    }
-                            	    break;
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
+            }
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "ruleExternalServiceTaskFlowElement"
 
-                            	default :
-                            	    break loop62;
-                                }
-                            } while (true);
 
+    // $ANTLR start "entryRuleBusinessRuleTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1411:1: entryRuleBusinessRuleTaskFlowElement returns [EObject current=null] : iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF ;
+    public final EObject entryRuleBusinessRuleTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
-                            }
-                            break;
+        EObject iv_ruleBusinessRuleTaskFlowElement = null;
 
-                    }
 
-                    this_LIST_CLOSED_24=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_25); 
+        try {
+            // InternalTestgeneratorDSL.g:1411:68: (iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1412:2: iv_ruleBusinessRuleTaskFlowElement= ruleBusinessRuleTaskFlowElement EOF
+            {
+             newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementRule()); 
+            pushFollow(FOLLOW_1);
+            iv_ruleBusinessRuleTaskFlowElement=ruleBusinessRuleTaskFlowElement();
 
-                    				newLeafNode(this_LIST_CLOSED_24, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_6_5());
-                    			
+            state._fsp--;
 
-                    }
-                    break;
+             current =iv_ruleBusinessRuleTaskFlowElement; 
+            match(input,EOF,FOLLOW_2); 
 
             }
 
-            // InternalTestgeneratorDSL.g:2392:3: (otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED )?
-            int alt67=2;
-            int LA67_0 = input.LA(1);
+        }
 
-            if ( (LA67_0==17) ) {
-                alt67=1;
+            catch (RecognitionException re) {
+                recover(input,re);
+                appendSkippedTokens();
             }
-            switch (alt67) {
-                case 1 :
-                    // InternalTestgeneratorDSL.g:2393:4: otherlv_25= 'with' otherlv_26= 'outputVariables' this_ASSOCIATION_27= RULE_ASSOCIATION this_LIST_OPEN_28= RULE_LIST_OPEN ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )? this_LIST_CLOSED_32= RULE_LIST_CLOSED
-                    {
-                    otherlv_25=(Token)match(input,17,FOLLOW_27); 
-
-                    				newLeafNode(otherlv_25, grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_7_0());
-                    			
-                    otherlv_26=(Token)match(input,31,FOLLOW_12); 
-
-                    				newLeafNode(otherlv_26, grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesKeyword_7_1());
-                    			
-                    this_ASSOCIATION_27=(Token)match(input,RULE_ASSOCIATION,FOLLOW_13); 
-
-                    				newLeafNode(this_ASSOCIATION_27, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_7_2());
-                    			
-                    this_LIST_OPEN_28=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
-
-                    				newLeafNode(this_LIST_OPEN_28, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_OPENTerminalRuleCall_7_3());
-                    			
-                    // InternalTestgeneratorDSL.g:2409:4: ( ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )* )?
-                    int alt66=2;
-                    int LA66_0 = input.LA(1);
-
-                    if ( (LA66_0==RULE_ID) ) {
-                        alt66=1;
-                    }
-                    switch (alt66) {
-                        case 1 :
-                            // InternalTestgeneratorDSL.g:2410:5: ( (lv_outputVariables_29_0= ruleVariableReference ) ) (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )*
-                            {
-                            // InternalTestgeneratorDSL.g:2410:5: ( (lv_outputVariables_29_0= ruleVariableReference ) )
-                            // InternalTestgeneratorDSL.g:2411:6: (lv_outputVariables_29_0= ruleVariableReference )
-                            {
-                            // InternalTestgeneratorDSL.g:2411:6: (lv_outputVariables_29_0= ruleVariableReference )
-                            // InternalTestgeneratorDSL.g:2412:7: lv_outputVariables_29_0= ruleVariableReference
-                            {
-
-                            							newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0());
-                            						
-                            pushFollow(FOLLOW_15);
-                            lv_outputVariables_29_0=ruleVariableReference();
-
-                            state._fsp--;
-
+        finally {
+        }
+        return current;
+    }
+    // $ANTLR end "entryRuleBusinessRuleTaskFlowElement"
 
-                            							if (current==null) {
-                            								current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
-                            							}
-                            							add(
-                            								current,
-                            								"outputVariables",
-                            								lv_outputVariables_29_0,
-                            								"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            							afterParserOrEnumRuleCall();
-                            						
 
-                            }
+    // $ANTLR start "ruleBusinessRuleTaskFlowElement"
+    // InternalTestgeneratorDSL.g:1418:1: ruleBusinessRuleTaskFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) ;
+    public final EObject ruleBusinessRuleTaskFlowElement() throws RecognitionException {
+        EObject current = null;
 
+        Token otherlv_0=null;
+        Token lv_name_1_0=null;
+        Token this_ASSOCIATION_2=null;
+        Token otherlv_3=null;
+        Token otherlv_4=null;
+        Token otherlv_5=null;
+        Token this_ASSOCIATION_6=null;
+        Token lv_resultVariable_7_0=null;
+        Token otherlv_8=null;
+        Token otherlv_9=null;
+        Token this_ASSOCIATION_10=null;
+        Token lv_label_11_0=null;
+        Token this_DECLARATION_FINISHED_12=null;
 
-                            }
 
-                            // InternalTestgeneratorDSL.g:2429:5: (this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) ) )*
-                            loop65:
-                            do {
-                                int alt65=2;
-                                int LA65_0 = input.LA(1);
+        	enterRule();
 
-                                if ( (LA65_0==RULE_SEPARATOR) ) {
-                                    alt65=1;
-                                }
+        try {
+            // InternalTestgeneratorDSL.g:1424:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1425:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
+            {
+            // InternalTestgeneratorDSL.g:1425:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1426:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'BusinessRuleTask' (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )? (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_12= RULE_DECLARATION_FINISHED
+            {
+            otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
+            			newLeafNode(otherlv_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getFlowElementKeyword_0());
+            		
+            // InternalTestgeneratorDSL.g:1430:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1431:4: (lv_name_1_0= RULE_ID )
+            {
+            // InternalTestgeneratorDSL.g:1431:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1432:5: lv_name_1_0= RULE_ID
+            {
+            lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
-                                switch (alt65) {
-                            	case 1 :
-                            	    // InternalTestgeneratorDSL.g:2430:6: this_SEPARATOR_30= RULE_SEPARATOR ( (lv_outputVariables_31_0= ruleVariableReference ) )
-                            	    {
-                            	    this_SEPARATOR_30=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
+            					newLeafNode(lv_name_1_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getNameIDTerminalRuleCall_1_0());
+            				
 
-                            	    						newLeafNode(this_SEPARATOR_30, grammarAccess.getBusinessRuleTaskFlowElementAccess().getSEPARATORTerminalRuleCall_7_4_1_0());
-                            	    					
-                            	    // InternalTestgeneratorDSL.g:2434:6: ( (lv_outputVariables_31_0= ruleVariableReference ) )
-                            	    // InternalTestgeneratorDSL.g:2435:7: (lv_outputVariables_31_0= ruleVariableReference )
-                            	    {
-                            	    // InternalTestgeneratorDSL.g:2435:7: (lv_outputVariables_31_0= ruleVariableReference )
-                            	    // InternalTestgeneratorDSL.g:2436:8: lv_outputVariables_31_0= ruleVariableReference
-                            	    {
+            					if (current==null) {
+            						current = createModelElement(grammarAccess.getBusinessRuleTaskFlowElementRule());
+            					}
+            					setWithLastConsumed(
+            						current,
+            						"name",
+            						lv_name_1_0,
+            						"de.fhmuenster.masterthesis.TestgeneratorDSL.ID");
+            				
 
-                            	    								newCompositeNode(grammarAccess.getBusinessRuleTaskFlowElementAccess().getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0());
-                            	    							
-                            	    pushFollow(FOLLOW_15);
-                            	    lv_outputVariables_31_0=ruleVariableReference();
+            }
 
-                            	    state._fsp--;
 
+            }
 
-                            	    								if (current==null) {
-                            	    									current = createModelElementForParent(grammarAccess.getBusinessRuleTaskFlowElementRule());
-                            	    								}
-                            	    								add(
-                            	    									current,
-                            	    									"outputVariables",
-                            	    									lv_outputVariables_31_0,
-                            	    									"de.fhmuenster.masterthesis.TestgeneratorDSL.VariableReference");
-                            	    								afterParserOrEnumRuleCall();
-                            	    							
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_33); 
 
-                            	    }
+            			newLeafNode(this_ASSOCIATION_2, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
+            		
+            otherlv_3=(Token)match(input,37,FOLLOW_23); 
 
+            			newLeafNode(otherlv_3, grammarAccess.getBusinessRuleTaskFlowElementAccess().getBusinessRuleTaskKeyword_3());
+            		
+            // InternalTestgeneratorDSL.g:1456:3: (otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) ) )?
+            int alt25=2;
+            int LA25_0 = input.LA(1);
 
-                            	    }
+            if ( (LA25_0==17) ) {
+                alt25=1;
+            }
+            switch (alt25) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:1457:4: otherlv_4= 'with' otherlv_5= 'resultVariable' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_resultVariable_7_0= RULE_STRING ) )
+                    {
+                    otherlv_4=(Token)match(input,17,FOLLOW_34); 
 
+                    				newLeafNode(otherlv_4, grammarAccess.getBusinessRuleTaskFlowElementAccess().getWithKeyword_4_0());
+                    			
+                    otherlv_5=(Token)match(input,38,FOLLOW_12); 
 
-                            	    }
-                            	    break;
+                    				newLeafNode(otherlv_5, grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableKeyword_4_1());
+                    			
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                            	default :
-                            	    break loop65;
-                                }
-                            } while (true);
+                    				newLeafNode(this_ASSOCIATION_6, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
+                    			
+                    // InternalTestgeneratorDSL.g:1469:4: ( (lv_resultVariable_7_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1470:5: (lv_resultVariable_7_0= RULE_STRING )
+                    {
+                    // InternalTestgeneratorDSL.g:1470:5: (lv_resultVariable_7_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1471:6: lv_resultVariable_7_0= RULE_STRING
+                    {
+                    lv_resultVariable_7_0=(Token)match(input,RULE_STRING,FOLLOW_24); 
 
+                    						newLeafNode(lv_resultVariable_7_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getResultVariableSTRINGTerminalRuleCall_4_3_0());
+                    					
 
-                            }
-                            break;
+                    						if (current==null) {
+                    							current = createModelElement(grammarAccess.getBusinessRuleTaskFlowElementRule());
+                    						}
+                    						setWithLastConsumed(
+                    							current,
+                    							"resultVariable",
+                    							lv_resultVariable_7_0,
+                    							"org.eclipse.xtext.common.Terminals.STRING");
+                    					
 
                     }
 
-                    this_LIST_CLOSED_32=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_28); 
 
-                    				newLeafNode(this_LIST_CLOSED_32, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLIST_CLOSEDTerminalRuleCall_7_5());
-                    			
+                    }
+
 
                     }
                     break;
 
             }
 
-            // InternalTestgeneratorDSL.g:2460:3: (otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) ) )?
-            int alt68=2;
-            int LA68_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:1488:3: (otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) ) )?
+            int alt26=2;
+            int LA26_0 = input.LA(1);
 
-            if ( (LA68_0==32) ) {
-                alt68=1;
+            if ( (LA26_0==28) ) {
+                alt26=1;
             }
-            switch (alt68) {
+            switch (alt26) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2461:4: otherlv_33= 'and' otherlv_34= 'label' this_ASSOCIATION_35= RULE_ASSOCIATION ( (lv_label_36_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1489:4: otherlv_8= 'and' otherlv_9= 'label' this_ASSOCIATION_10= RULE_ASSOCIATION ( (lv_label_11_0= RULE_STRING ) )
                     {
-                    otherlv_33=(Token)match(input,32,FOLLOW_29); 
+                    otherlv_8=(Token)match(input,28,FOLLOW_25); 
 
-                    				newLeafNode(otherlv_33, grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_8_0());
+                    				newLeafNode(otherlv_8, grammarAccess.getBusinessRuleTaskFlowElementAccess().getAndKeyword_5_0());
                     			
-                    otherlv_34=(Token)match(input,33,FOLLOW_12); 
+                    otherlv_9=(Token)match(input,29,FOLLOW_12); 
 
-                    				newLeafNode(otherlv_34, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_8_1());
+                    				newLeafNode(otherlv_9, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelKeyword_5_1());
                     			
-                    this_ASSOCIATION_35=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
+                    this_ASSOCIATION_10=(Token)match(input,RULE_ASSOCIATION,FOLLOW_7); 
 
-                    				newLeafNode(this_ASSOCIATION_35, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_8_2());
+                    				newLeafNode(this_ASSOCIATION_10, grammarAccess.getBusinessRuleTaskFlowElementAccess().getASSOCIATIONTerminalRuleCall_5_2());
                     			
-                    // InternalTestgeneratorDSL.g:2473:4: ( (lv_label_36_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:2474:5: (lv_label_36_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1501:4: ( (lv_label_11_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1502:5: (lv_label_11_0= RULE_STRING )
                     {
-                    // InternalTestgeneratorDSL.g:2474:5: (lv_label_36_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:2475:6: lv_label_36_0= RULE_STRING
+                    // InternalTestgeneratorDSL.g:1502:5: (lv_label_11_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1503:6: lv_label_11_0= RULE_STRING
                     {
-                    lv_label_36_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
+                    lv_label_11_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
-                    						newLeafNode(lv_label_36_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_8_3_0());
+                    						newLeafNode(lv_label_11_0, grammarAccess.getBusinessRuleTaskFlowElementAccess().getLabelSTRINGTerminalRuleCall_5_3_0());
                     					
 
                     						if (current==null) {
@@ -5711,7 +3481,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     						setWithLastConsumed(
                     							current,
                     							"label",
-                    							lv_label_36_0,
+                    							lv_label_11_0,
                     							"org.eclipse.xtext.common.Terminals.STRING");
                     					
 
@@ -5726,9 +3496,9 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_DECLARATION_FINISHED_37=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
+            this_DECLARATION_FINISHED_12=(Token)match(input,RULE_DECLARATION_FINISHED,FOLLOW_2); 
 
-            			newLeafNode(this_DECLARATION_FINISHED_37, grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_9());
+            			newLeafNode(this_DECLARATION_FINISHED_12, grammarAccess.getBusinessRuleTaskFlowElementAccess().getDECLARATION_FINISHEDTerminalRuleCall_6());
             		
 
             }
@@ -5753,7 +3523,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleGatewayFlowElement"
-    // InternalTestgeneratorDSL.g:2500:1: entryRuleGatewayFlowElement returns [EObject current=null] : iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF ;
+    // InternalTestgeneratorDSL.g:1528:1: entryRuleGatewayFlowElement returns [EObject current=null] : iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF ;
     public final EObject entryRuleGatewayFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -5761,8 +3531,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2500:59: (iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF )
-            // InternalTestgeneratorDSL.g:2501:2: iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF
+            // InternalTestgeneratorDSL.g:1528:59: (iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1529:2: iv_ruleGatewayFlowElement= ruleGatewayFlowElement EOF
             {
              newCompositeNode(grammarAccess.getGatewayFlowElementRule()); 
             pushFollow(FOLLOW_1);
@@ -5789,7 +3559,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleGatewayFlowElement"
-    // InternalTestgeneratorDSL.g:2507:1: ruleGatewayFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:1535:1: ruleGatewayFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleGatewayFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -5803,21 +3573,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2513:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2514:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1541:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1542:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2514:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2515:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1542:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1543:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'Gateway' this_DECLARATION_FINISHED_4= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getGatewayFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2519:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2520:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1547:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1548:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2520:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2521:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1548:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1549:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
@@ -5839,11 +3609,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_37); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_35); 
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getGatewayFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,41,FOLLOW_17); 
+            otherlv_3=(Token)match(input,39,FOLLOW_17); 
 
             			newLeafNode(otherlv_3, grammarAccess.getGatewayFlowElementAccess().getGatewayKeyword_3());
             		
@@ -5874,7 +3644,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleSequenceFlowElement"
-    // InternalTestgeneratorDSL.g:2553:1: entryRuleSequenceFlowElement returns [EObject current=null] : iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF ;
+    // InternalTestgeneratorDSL.g:1581:1: entryRuleSequenceFlowElement returns [EObject current=null] : iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF ;
     public final EObject entryRuleSequenceFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -5882,8 +3652,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2553:60: (iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF )
-            // InternalTestgeneratorDSL.g:2554:2: iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF
+            // InternalTestgeneratorDSL.g:1581:60: (iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF )
+            // InternalTestgeneratorDSL.g:1582:2: iv_ruleSequenceFlowElement= ruleSequenceFlowElement EOF
             {
              newCompositeNode(grammarAccess.getSequenceFlowElementRule()); 
             pushFollow(FOLLOW_1);
@@ -5910,7 +3680,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleSequenceFlowElement"
-    // InternalTestgeneratorDSL.g:2560:1: ruleSequenceFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:1588:1: ruleSequenceFlowElement returns [EObject current=null] : (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleSequenceFlowElement() throws RecognitionException {
         EObject current = null;
 
@@ -5928,21 +3698,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2566:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2567:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1594:2: ( (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1595:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2567:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2568:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1595:2: (otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1596:3: otherlv_0= 'FlowElement' ( (lv_name_1_0= RULE_ID ) ) this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'SequenceFlow' (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
             {
             otherlv_0=(Token)match(input,23,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getSequenceFlowElementAccess().getFlowElementKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2572:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2573:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1600:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1601:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2573:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2574:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1601:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1602:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_12); 
 
@@ -5964,30 +3734,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_38); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_36); 
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,42,FOLLOW_10); 
+            otherlv_3=(Token)match(input,40,FOLLOW_10); 
 
             			newLeafNode(otherlv_3, grammarAccess.getSequenceFlowElementAccess().getSequenceFlowKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:2598:3: (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )?
-            int alt69=2;
-            int LA69_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:1626:3: (otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) ) )?
+            int alt27=2;
+            int LA27_0 = input.LA(1);
 
-            if ( (LA69_0==17) ) {
-                alt69=1;
+            if ( (LA27_0==17) ) {
+                alt27=1;
             }
-            switch (alt69) {
+            switch (alt27) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2599:4: otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1627:4: otherlv_4= 'with' otherlv_5= 'expression' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_expression_7_0= RULE_STRING ) )
                     {
-                    otherlv_4=(Token)match(input,17,FOLLOW_39); 
+                    otherlv_4=(Token)match(input,17,FOLLOW_37); 
 
                     				newLeafNode(otherlv_4, grammarAccess.getSequenceFlowElementAccess().getWithKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,43,FOLLOW_12); 
+                    otherlv_5=(Token)match(input,41,FOLLOW_12); 
 
                     				newLeafNode(otherlv_5, grammarAccess.getSequenceFlowElementAccess().getExpressionKeyword_4_1());
                     			
@@ -5995,11 +3765,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     				newLeafNode(this_ASSOCIATION_6, grammarAccess.getSequenceFlowElementAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    // InternalTestgeneratorDSL.g:2611:4: ( (lv_expression_7_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:2612:5: (lv_expression_7_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1639:4: ( (lv_expression_7_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1640:5: (lv_expression_7_0= RULE_STRING )
                     {
-                    // InternalTestgeneratorDSL.g:2612:5: (lv_expression_7_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:2613:6: lv_expression_7_0= RULE_STRING
+                    // InternalTestgeneratorDSL.g:1640:5: (lv_expression_7_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1641:6: lv_expression_7_0= RULE_STRING
                     {
                     lv_expression_7_0=(Token)match(input,RULE_STRING,FOLLOW_17); 
 
@@ -6054,7 +3824,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleFlowElementReference"
-    // InternalTestgeneratorDSL.g:2638:1: entryRuleFlowElementReference returns [EObject current=null] : iv_ruleFlowElementReference= ruleFlowElementReference EOF ;
+    // InternalTestgeneratorDSL.g:1666:1: entryRuleFlowElementReference returns [EObject current=null] : iv_ruleFlowElementReference= ruleFlowElementReference EOF ;
     public final EObject entryRuleFlowElementReference() throws RecognitionException {
         EObject current = null;
 
@@ -6062,8 +3832,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2638:61: (iv_ruleFlowElementReference= ruleFlowElementReference EOF )
-            // InternalTestgeneratorDSL.g:2639:2: iv_ruleFlowElementReference= ruleFlowElementReference EOF
+            // InternalTestgeneratorDSL.g:1666:61: (iv_ruleFlowElementReference= ruleFlowElementReference EOF )
+            // InternalTestgeneratorDSL.g:1667:2: iv_ruleFlowElementReference= ruleFlowElementReference EOF
             {
              newCompositeNode(grammarAccess.getFlowElementReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -6090,34 +3860,99 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleFlowElementReference"
-    // InternalTestgeneratorDSL.g:2645:1: ruleFlowElementReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:1673:1: ruleFlowElementReference returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )? ) ;
     public final EObject ruleFlowElementReference() throws RecognitionException {
         EObject current = null;
 
         Token otherlv_0=null;
+        Token this_ASSOCIATION_1=null;
+        Enumerator lv_flag_2_0 = null;
+
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2651:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:2652:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1679:2: ( ( ( (otherlv_0= RULE_ID ) ) (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )? ) )
+            // InternalTestgeneratorDSL.g:1680:2: ( ( (otherlv_0= RULE_ID ) ) (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )? )
             {
-            // InternalTestgeneratorDSL.g:2652:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2653:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1680:2: ( ( (otherlv_0= RULE_ID ) ) (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )? )
+            // InternalTestgeneratorDSL.g:1681:3: ( (otherlv_0= RULE_ID ) ) (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )?
             {
-            // InternalTestgeneratorDSL.g:2653:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2654:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1681:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1682:4: (otherlv_0= RULE_ID )
+            {
+            // InternalTestgeneratorDSL.g:1682:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1683:5: otherlv_0= RULE_ID
             {
 
-            				if (current==null) {
-            					current = createModelElement(grammarAccess.getFlowElementReferenceRule());
-            				}
-            			
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_2); 
+            					if (current==null) {
+            						current = createModelElement(grammarAccess.getFlowElementReferenceRule());
+            					}
+            				
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_38); 
 
-            				newLeafNode(otherlv_0, grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0());
-            			
+            					newLeafNode(otherlv_0, grammarAccess.getFlowElementReferenceAccess().getRefFlowElementCrossReference_0_0());
+            				
+
+            }
+
+
+            }
+
+            // InternalTestgeneratorDSL.g:1694:3: (this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) ) )?
+            int alt28=2;
+            int LA28_0 = input.LA(1);
+
+            if ( (LA28_0==RULE_ASSOCIATION) ) {
+                int LA28_1 = input.LA(2);
+
+                if ( ((LA28_1>=82 && LA28_1<=85)) ) {
+                    alt28=1;
+                }
+            }
+            switch (alt28) {
+                case 1 :
+                    // InternalTestgeneratorDSL.g:1695:4: this_ASSOCIATION_1= RULE_ASSOCIATION ( (lv_flag_2_0= ruleFlag ) )
+                    {
+                    this_ASSOCIATION_1=(Token)match(input,RULE_ASSOCIATION,FOLLOW_39); 
+
+                    				newLeafNode(this_ASSOCIATION_1, grammarAccess.getFlowElementReferenceAccess().getASSOCIATIONTerminalRuleCall_1_0());
+                    			
+                    // InternalTestgeneratorDSL.g:1699:4: ( (lv_flag_2_0= ruleFlag ) )
+                    // InternalTestgeneratorDSL.g:1700:5: (lv_flag_2_0= ruleFlag )
+                    {
+                    // InternalTestgeneratorDSL.g:1700:5: (lv_flag_2_0= ruleFlag )
+                    // InternalTestgeneratorDSL.g:1701:6: lv_flag_2_0= ruleFlag
+                    {
+
+                    						newCompositeNode(grammarAccess.getFlowElementReferenceAccess().getFlagFlagEnumRuleCall_1_1_0());
+                    					
+                    pushFollow(FOLLOW_2);
+                    lv_flag_2_0=ruleFlag();
+
+                    state._fsp--;
+
+
+                    						if (current==null) {
+                    							current = createModelElementForParent(grammarAccess.getFlowElementReferenceRule());
+                    						}
+                    						set(
+                    							current,
+                    							"flag",
+                    							lv_flag_2_0,
+                    							"de.fhmuenster.masterthesis.TestgeneratorDSL.Flag");
+                    						afterParserOrEnumRuleCall();
+                    					
+
+                    }
+
+
+                    }
+
+
+                    }
+                    break;
 
             }
 
@@ -6144,7 +3979,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleDelegateServiceTaskReference"
-    // InternalTestgeneratorDSL.g:2668:1: entryRuleDelegateServiceTaskReference returns [EObject current=null] : iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF ;
+    // InternalTestgeneratorDSL.g:1723:1: entryRuleDelegateServiceTaskReference returns [EObject current=null] : iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF ;
     public final EObject entryRuleDelegateServiceTaskReference() throws RecognitionException {
         EObject current = null;
 
@@ -6152,8 +3987,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2668:69: (iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF )
-            // InternalTestgeneratorDSL.g:2669:2: iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF
+            // InternalTestgeneratorDSL.g:1723:69: (iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF )
+            // InternalTestgeneratorDSL.g:1724:2: iv_ruleDelegateServiceTaskReference= ruleDelegateServiceTaskReference EOF
             {
              newCompositeNode(grammarAccess.getDelegateServiceTaskReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -6180,7 +4015,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleDelegateServiceTaskReference"
-    // InternalTestgeneratorDSL.g:2675:1: ruleDelegateServiceTaskReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:1730:1: ruleDelegateServiceTaskReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
     public final EObject ruleDelegateServiceTaskReference() throws RecognitionException {
         EObject current = null;
 
@@ -6190,14 +4025,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2681:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:2682:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1736:2: ( ( (otherlv_0= RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:1737:2: ( (otherlv_0= RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:2682:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2683:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1737:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1738:3: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2683:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2684:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1738:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1739:4: otherlv_0= RULE_ID
             {
 
             				if (current==null) {
@@ -6234,7 +4069,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleExternalTopic"
-    // InternalTestgeneratorDSL.g:2698:1: entryRuleExternalTopic returns [EObject current=null] : iv_ruleExternalTopic= ruleExternalTopic EOF ;
+    // InternalTestgeneratorDSL.g:1753:1: entryRuleExternalTopic returns [EObject current=null] : iv_ruleExternalTopic= ruleExternalTopic EOF ;
     public final EObject entryRuleExternalTopic() throws RecognitionException {
         EObject current = null;
 
@@ -6242,8 +4077,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2698:54: (iv_ruleExternalTopic= ruleExternalTopic EOF )
-            // InternalTestgeneratorDSL.g:2699:2: iv_ruleExternalTopic= ruleExternalTopic EOF
+            // InternalTestgeneratorDSL.g:1753:54: (iv_ruleExternalTopic= ruleExternalTopic EOF )
+            // InternalTestgeneratorDSL.g:1754:2: iv_ruleExternalTopic= ruleExternalTopic EOF
             {
              newCompositeNode(grammarAccess.getExternalTopicRule()); 
             pushFollow(FOLLOW_1);
@@ -6270,7 +4105,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleExternalTopic"
-    // InternalTestgeneratorDSL.g:2705:1: ruleExternalTopic returns [EObject current=null] : (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:1760:1: ruleExternalTopic returns [EObject current=null] : (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleExternalTopic() throws RecognitionException {
         EObject current = null;
 
@@ -6282,21 +4117,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2711:2: ( (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2712:2: (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1766:2: ( (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1767:2: (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2712:2: (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2713:3: otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1767:2: (otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1768:3: otherlv_0= 'ExternalTopic' ( (lv_name_1_0= RULE_ID ) ) this_DECLARATION_FINISHED_2= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,44,FOLLOW_4); 
+            otherlv_0=(Token)match(input,42,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getExternalTopicAccess().getExternalTopicKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2717:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2718:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1772:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1773:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2718:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2719:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1773:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1774:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_17); 
 
@@ -6345,7 +4180,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleExternalTopicReference"
-    // InternalTestgeneratorDSL.g:2743:1: entryRuleExternalTopicReference returns [EObject current=null] : iv_ruleExternalTopicReference= ruleExternalTopicReference EOF ;
+    // InternalTestgeneratorDSL.g:1798:1: entryRuleExternalTopicReference returns [EObject current=null] : iv_ruleExternalTopicReference= ruleExternalTopicReference EOF ;
     public final EObject entryRuleExternalTopicReference() throws RecognitionException {
         EObject current = null;
 
@@ -6353,8 +4188,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2743:63: (iv_ruleExternalTopicReference= ruleExternalTopicReference EOF )
-            // InternalTestgeneratorDSL.g:2744:2: iv_ruleExternalTopicReference= ruleExternalTopicReference EOF
+            // InternalTestgeneratorDSL.g:1798:63: (iv_ruleExternalTopicReference= ruleExternalTopicReference EOF )
+            // InternalTestgeneratorDSL.g:1799:2: iv_ruleExternalTopicReference= ruleExternalTopicReference EOF
             {
              newCompositeNode(grammarAccess.getExternalTopicReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -6381,7 +4216,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleExternalTopicReference"
-    // InternalTestgeneratorDSL.g:2750:1: ruleExternalTopicReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:1805:1: ruleExternalTopicReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
     public final EObject ruleExternalTopicReference() throws RecognitionException {
         EObject current = null;
 
@@ -6391,14 +4226,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2756:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:2757:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1811:2: ( ( (otherlv_0= RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:1812:2: ( (otherlv_0= RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:2757:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2758:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1812:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1813:3: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2758:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2759:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1813:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1814:4: otherlv_0= RULE_ID
             {
 
             				if (current==null) {
@@ -6435,7 +4270,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariable"
-    // InternalTestgeneratorDSL.g:2773:1: entryRuleVariable returns [EObject current=null] : iv_ruleVariable= ruleVariable EOF ;
+    // InternalTestgeneratorDSL.g:1828:1: entryRuleVariable returns [EObject current=null] : iv_ruleVariable= ruleVariable EOF ;
     public final EObject entryRuleVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6443,8 +4278,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2773:49: (iv_ruleVariable= ruleVariable EOF )
-            // InternalTestgeneratorDSL.g:2774:2: iv_ruleVariable= ruleVariable EOF
+            // InternalTestgeneratorDSL.g:1828:49: (iv_ruleVariable= ruleVariable EOF )
+            // InternalTestgeneratorDSL.g:1829:2: iv_ruleVariable= ruleVariable EOF
             {
              newCompositeNode(grammarAccess.getVariableRule()); 
             pushFollow(FOLLOW_1);
@@ -6471,7 +4306,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariable"
-    // InternalTestgeneratorDSL.g:2780:1: ruleVariable returns [EObject current=null] : (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable ) ;
+    // InternalTestgeneratorDSL.g:1835:1: ruleVariable returns [EObject current=null] : (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable ) ;
     public final EObject ruleVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6486,37 +4321,37 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2786:2: ( (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable ) )
-            // InternalTestgeneratorDSL.g:2787:2: (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable )
+            // InternalTestgeneratorDSL.g:1841:2: ( (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable ) )
+            // InternalTestgeneratorDSL.g:1842:2: (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable )
             {
-            // InternalTestgeneratorDSL.g:2787:2: (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable )
-            int alt70=3;
+            // InternalTestgeneratorDSL.g:1842:2: (this_StringVariable_0= ruleStringVariable | this_IntVariable_1= ruleIntVariable | this_BooleanVariable_2= ruleBooleanVariable )
+            int alt29=3;
             switch ( input.LA(1) ) {
-            case 45:
+            case 43:
                 {
-                alt70=1;
+                alt29=1;
                 }
                 break;
-            case 47:
+            case 45:
                 {
-                alt70=2;
+                alt29=2;
                 }
                 break;
-            case 48:
+            case 46:
                 {
-                alt70=3;
+                alt29=3;
                 }
                 break;
             default:
                 NoViableAltException nvae =
-                    new NoViableAltException("", 70, 0, input);
+                    new NoViableAltException("", 29, 0, input);
 
                 throw nvae;
             }
 
-            switch (alt70) {
+            switch (alt29) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2788:3: this_StringVariable_0= ruleStringVariable
+                    // InternalTestgeneratorDSL.g:1843:3: this_StringVariable_0= ruleStringVariable
                     {
 
                     			newCompositeNode(grammarAccess.getVariableAccess().getStringVariableParserRuleCall_0());
@@ -6534,7 +4369,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:2797:3: this_IntVariable_1= ruleIntVariable
+                    // InternalTestgeneratorDSL.g:1852:3: this_IntVariable_1= ruleIntVariable
                     {
 
                     			newCompositeNode(grammarAccess.getVariableAccess().getIntVariableParserRuleCall_1());
@@ -6552,7 +4387,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:2806:3: this_BooleanVariable_2= ruleBooleanVariable
+                    // InternalTestgeneratorDSL.g:1861:3: this_BooleanVariable_2= ruleBooleanVariable
                     {
 
                     			newCompositeNode(grammarAccess.getVariableAccess().getBooleanVariableParserRuleCall_2());
@@ -6592,7 +4427,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariableReference"
-    // InternalTestgeneratorDSL.g:2818:1: entryRuleVariableReference returns [EObject current=null] : iv_ruleVariableReference= ruleVariableReference EOF ;
+    // InternalTestgeneratorDSL.g:1873:1: entryRuleVariableReference returns [EObject current=null] : iv_ruleVariableReference= ruleVariableReference EOF ;
     public final EObject entryRuleVariableReference() throws RecognitionException {
         EObject current = null;
 
@@ -6600,8 +4435,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2818:58: (iv_ruleVariableReference= ruleVariableReference EOF )
-            // InternalTestgeneratorDSL.g:2819:2: iv_ruleVariableReference= ruleVariableReference EOF
+            // InternalTestgeneratorDSL.g:1873:58: (iv_ruleVariableReference= ruleVariableReference EOF )
+            // InternalTestgeneratorDSL.g:1874:2: iv_ruleVariableReference= ruleVariableReference EOF
             {
              newCompositeNode(grammarAccess.getVariableReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -6628,7 +4463,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariableReference"
-    // InternalTestgeneratorDSL.g:2825:1: ruleVariableReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:1880:1: ruleVariableReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
     public final EObject ruleVariableReference() throws RecognitionException {
         EObject current = null;
 
@@ -6638,14 +4473,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2831:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:2832:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1886:2: ( ( (otherlv_0= RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:1887:2: ( (otherlv_0= RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:2832:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2833:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1887:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1888:3: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2833:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2834:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1888:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1889:4: otherlv_0= RULE_ID
             {
 
             				if (current==null) {
@@ -6682,7 +4517,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleStringVariable"
-    // InternalTestgeneratorDSL.g:2848:1: entryRuleStringVariable returns [EObject current=null] : iv_ruleStringVariable= ruleStringVariable EOF ;
+    // InternalTestgeneratorDSL.g:1903:1: entryRuleStringVariable returns [EObject current=null] : iv_ruleStringVariable= ruleStringVariable EOF ;
     public final EObject entryRuleStringVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6690,8 +4525,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2848:55: (iv_ruleStringVariable= ruleStringVariable EOF )
-            // InternalTestgeneratorDSL.g:2849:2: iv_ruleStringVariable= ruleStringVariable EOF
+            // InternalTestgeneratorDSL.g:1903:55: (iv_ruleStringVariable= ruleStringVariable EOF )
+            // InternalTestgeneratorDSL.g:1904:2: iv_ruleStringVariable= ruleStringVariable EOF
             {
              newCompositeNode(grammarAccess.getStringVariableRule()); 
             pushFollow(FOLLOW_1);
@@ -6718,7 +4553,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringVariable"
-    // InternalTestgeneratorDSL.g:2855:1: ruleStringVariable returns [EObject current=null] : (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:1910:1: ruleStringVariable returns [EObject current=null] : (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleStringVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6738,21 +4573,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2861:2: ( (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2862:2: (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1916:2: ( (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:1917:2: (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2862:2: (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2863:3: otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:1917:2: (otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:1918:3: otherlv_0= 'String' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,45,FOLLOW_4); 
+            otherlv_0=(Token)match(input,43,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getStringVariableAccess().getStringKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2867:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2868:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1922:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:1923:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2868:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2869:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:1923:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:1924:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_5); 
 
@@ -6778,7 +4613,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_2, grammarAccess.getStringVariableAccess().getWithKeyword_2());
             		
-            otherlv_3=(Token)match(input,46,FOLLOW_12); 
+            otherlv_3=(Token)match(input,44,FOLLOW_12); 
 
             			newLeafNode(otherlv_3, grammarAccess.getStringVariableAccess().getProposalsKeyword_3());
             		
@@ -6790,22 +4625,22 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_LIST_OPEN_5, grammarAccess.getStringVariableAccess().getLIST_OPENTerminalRuleCall_5());
             		
-            // InternalTestgeneratorDSL.g:2901:3: ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )?
-            int alt72=2;
-            int LA72_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:1956:3: ( ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )* )?
+            int alt31=2;
+            int LA31_0 = input.LA(1);
 
-            if ( (LA72_0==RULE_STRING) ) {
-                alt72=1;
+            if ( (LA31_0==RULE_STRING) ) {
+                alt31=1;
             }
-            switch (alt72) {
+            switch (alt31) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:2902:4: ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )*
+                    // InternalTestgeneratorDSL.g:1957:4: ( (lv_proposals_6_0= RULE_STRING ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:2902:4: ( (lv_proposals_6_0= RULE_STRING ) )
-                    // InternalTestgeneratorDSL.g:2903:5: (lv_proposals_6_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1957:4: ( (lv_proposals_6_0= RULE_STRING ) )
+                    // InternalTestgeneratorDSL.g:1958:5: (lv_proposals_6_0= RULE_STRING )
                     {
-                    // InternalTestgeneratorDSL.g:2903:5: (lv_proposals_6_0= RULE_STRING )
-                    // InternalTestgeneratorDSL.g:2904:6: lv_proposals_6_0= RULE_STRING
+                    // InternalTestgeneratorDSL.g:1958:5: (lv_proposals_6_0= RULE_STRING )
+                    // InternalTestgeneratorDSL.g:1959:6: lv_proposals_6_0= RULE_STRING
                     {
                     lv_proposals_6_0=(Token)match(input,RULE_STRING,FOLLOW_15); 
 
@@ -6827,30 +4662,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:2920:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )*
-                    loop71:
+                    // InternalTestgeneratorDSL.g:1975:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) ) )*
+                    loop30:
                     do {
-                        int alt71=2;
-                        int LA71_0 = input.LA(1);
+                        int alt30=2;
+                        int LA30_0 = input.LA(1);
 
-                        if ( (LA71_0==RULE_SEPARATOR) ) {
-                            alt71=1;
+                        if ( (LA30_0==RULE_SEPARATOR) ) {
+                            alt30=1;
                         }
 
 
-                        switch (alt71) {
+                        switch (alt30) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:2921:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) )
+                    	    // InternalTestgeneratorDSL.g:1976:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_STRING ) )
                     	    {
                     	    this_SEPARATOR_7=(Token)match(input,RULE_SEPARATOR,FOLLOW_7); 
 
                     	    					newLeafNode(this_SEPARATOR_7, grammarAccess.getStringVariableAccess().getSEPARATORTerminalRuleCall_6_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:2925:5: ( (lv_proposals_8_0= RULE_STRING ) )
-                    	    // InternalTestgeneratorDSL.g:2926:6: (lv_proposals_8_0= RULE_STRING )
+                    	    // InternalTestgeneratorDSL.g:1980:5: ( (lv_proposals_8_0= RULE_STRING ) )
+                    	    // InternalTestgeneratorDSL.g:1981:6: (lv_proposals_8_0= RULE_STRING )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:2926:6: (lv_proposals_8_0= RULE_STRING )
-                    	    // InternalTestgeneratorDSL.g:2927:7: lv_proposals_8_0= RULE_STRING
+                    	    // InternalTestgeneratorDSL.g:1981:6: (lv_proposals_8_0= RULE_STRING )
+                    	    // InternalTestgeneratorDSL.g:1982:7: lv_proposals_8_0= RULE_STRING
                     	    {
                     	    lv_proposals_8_0=(Token)match(input,RULE_STRING,FOLLOW_15); 
 
@@ -6877,7 +4712,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop71;
+                    	    break loop30;
                         }
                     } while (true);
 
@@ -6918,7 +4753,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleIntVariable"
-    // InternalTestgeneratorDSL.g:2957:1: entryRuleIntVariable returns [EObject current=null] : iv_ruleIntVariable= ruleIntVariable EOF ;
+    // InternalTestgeneratorDSL.g:2012:1: entryRuleIntVariable returns [EObject current=null] : iv_ruleIntVariable= ruleIntVariable EOF ;
     public final EObject entryRuleIntVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6926,8 +4761,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:2957:52: (iv_ruleIntVariable= ruleIntVariable EOF )
-            // InternalTestgeneratorDSL.g:2958:2: iv_ruleIntVariable= ruleIntVariable EOF
+            // InternalTestgeneratorDSL.g:2012:52: (iv_ruleIntVariable= ruleIntVariable EOF )
+            // InternalTestgeneratorDSL.g:2013:2: iv_ruleIntVariable= ruleIntVariable EOF
             {
              newCompositeNode(grammarAccess.getIntVariableRule()); 
             pushFollow(FOLLOW_1);
@@ -6954,7 +4789,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntVariable"
-    // InternalTestgeneratorDSL.g:2964:1: ruleIntVariable returns [EObject current=null] : (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2019:1: ruleIntVariable returns [EObject current=null] : (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleIntVariable() throws RecognitionException {
         EObject current = null;
 
@@ -6974,21 +4809,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:2970:2: ( (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:2971:2: (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2025:2: ( (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2026:2: (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:2971:2: (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:2972:3: otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2026:2: (otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2027:3: otherlv_0= 'Integer' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,47,FOLLOW_4); 
+            otherlv_0=(Token)match(input,45,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getIntVariableAccess().getIntegerKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:2976:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:2977:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2031:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2032:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:2977:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:2978:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2032:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2033:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_5); 
 
@@ -7014,7 +4849,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_2, grammarAccess.getIntVariableAccess().getWithKeyword_2());
             		
-            otherlv_3=(Token)match(input,46,FOLLOW_12); 
+            otherlv_3=(Token)match(input,44,FOLLOW_12); 
 
             			newLeafNode(otherlv_3, grammarAccess.getIntVariableAccess().getProposalsKeyword_3());
             		
@@ -7026,22 +4861,22 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_LIST_OPEN_5, grammarAccess.getIntVariableAccess().getLIST_OPENTerminalRuleCall_5());
             		
-            // InternalTestgeneratorDSL.g:3010:3: ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )?
-            int alt74=2;
-            int LA74_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2065:3: ( ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )* )?
+            int alt33=2;
+            int LA33_0 = input.LA(1);
 
-            if ( (LA74_0==RULE_INT) ) {
-                alt74=1;
+            if ( (LA33_0==RULE_INT) ) {
+                alt33=1;
             }
-            switch (alt74) {
+            switch (alt33) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3011:4: ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )*
+                    // InternalTestgeneratorDSL.g:2066:4: ( (lv_proposals_6_0= RULE_INT ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3011:4: ( (lv_proposals_6_0= RULE_INT ) )
-                    // InternalTestgeneratorDSL.g:3012:5: (lv_proposals_6_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2066:4: ( (lv_proposals_6_0= RULE_INT ) )
+                    // InternalTestgeneratorDSL.g:2067:5: (lv_proposals_6_0= RULE_INT )
                     {
-                    // InternalTestgeneratorDSL.g:3012:5: (lv_proposals_6_0= RULE_INT )
-                    // InternalTestgeneratorDSL.g:3013:6: lv_proposals_6_0= RULE_INT
+                    // InternalTestgeneratorDSL.g:2067:5: (lv_proposals_6_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2068:6: lv_proposals_6_0= RULE_INT
                     {
                     lv_proposals_6_0=(Token)match(input,RULE_INT,FOLLOW_15); 
 
@@ -7063,30 +4898,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3029:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )*
-                    loop73:
+                    // InternalTestgeneratorDSL.g:2084:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) ) )*
+                    loop32:
                     do {
-                        int alt73=2;
-                        int LA73_0 = input.LA(1);
+                        int alt32=2;
+                        int LA32_0 = input.LA(1);
 
-                        if ( (LA73_0==RULE_SEPARATOR) ) {
-                            alt73=1;
+                        if ( (LA32_0==RULE_SEPARATOR) ) {
+                            alt32=1;
                         }
 
 
-                        switch (alt73) {
+                        switch (alt32) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3030:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) )
+                    	    // InternalTestgeneratorDSL.g:2085:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= RULE_INT ) )
                     	    {
                     	    this_SEPARATOR_7=(Token)match(input,RULE_SEPARATOR,FOLLOW_42); 
 
                     	    					newLeafNode(this_SEPARATOR_7, grammarAccess.getIntVariableAccess().getSEPARATORTerminalRuleCall_6_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3034:5: ( (lv_proposals_8_0= RULE_INT ) )
-                    	    // InternalTestgeneratorDSL.g:3035:6: (lv_proposals_8_0= RULE_INT )
+                    	    // InternalTestgeneratorDSL.g:2089:5: ( (lv_proposals_8_0= RULE_INT ) )
+                    	    // InternalTestgeneratorDSL.g:2090:6: (lv_proposals_8_0= RULE_INT )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3035:6: (lv_proposals_8_0= RULE_INT )
-                    	    // InternalTestgeneratorDSL.g:3036:7: lv_proposals_8_0= RULE_INT
+                    	    // InternalTestgeneratorDSL.g:2090:6: (lv_proposals_8_0= RULE_INT )
+                    	    // InternalTestgeneratorDSL.g:2091:7: lv_proposals_8_0= RULE_INT
                     	    {
                     	    lv_proposals_8_0=(Token)match(input,RULE_INT,FOLLOW_15); 
 
@@ -7113,7 +4948,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop73;
+                    	    break loop32;
                         }
                     } while (true);
 
@@ -7154,7 +4989,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleBooleanVariable"
-    // InternalTestgeneratorDSL.g:3066:1: entryRuleBooleanVariable returns [EObject current=null] : iv_ruleBooleanVariable= ruleBooleanVariable EOF ;
+    // InternalTestgeneratorDSL.g:2121:1: entryRuleBooleanVariable returns [EObject current=null] : iv_ruleBooleanVariable= ruleBooleanVariable EOF ;
     public final EObject entryRuleBooleanVariable() throws RecognitionException {
         EObject current = null;
 
@@ -7162,8 +4997,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3066:56: (iv_ruleBooleanVariable= ruleBooleanVariable EOF )
-            // InternalTestgeneratorDSL.g:3067:2: iv_ruleBooleanVariable= ruleBooleanVariable EOF
+            // InternalTestgeneratorDSL.g:2121:56: (iv_ruleBooleanVariable= ruleBooleanVariable EOF )
+            // InternalTestgeneratorDSL.g:2122:2: iv_ruleBooleanVariable= ruleBooleanVariable EOF
             {
              newCompositeNode(grammarAccess.getBooleanVariableRule()); 
             pushFollow(FOLLOW_1);
@@ -7190,7 +5025,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanVariable"
-    // InternalTestgeneratorDSL.g:3073:1: ruleBooleanVariable returns [EObject current=null] : (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2128:1: ruleBooleanVariable returns [EObject current=null] : (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleBooleanVariable() throws RecognitionException {
         EObject current = null;
 
@@ -7212,21 +5047,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3079:2: ( (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3080:2: (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2134:2: ( (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2135:2: (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3080:2: (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3081:3: otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2135:2: (otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2136:3: otherlv_0= 'Boolean' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'with' otherlv_3= 'proposals' this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,48,FOLLOW_4); 
+            otherlv_0=(Token)match(input,46,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getBooleanVariableAccess().getBooleanKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:3085:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:3086:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2140:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2141:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:3086:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:3087:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2141:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2142:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_5); 
 
@@ -7252,7 +5087,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_2, grammarAccess.getBooleanVariableAccess().getWithKeyword_2());
             		
-            otherlv_3=(Token)match(input,46,FOLLOW_12); 
+            otherlv_3=(Token)match(input,44,FOLLOW_12); 
 
             			newLeafNode(otherlv_3, grammarAccess.getBooleanVariableAccess().getProposalsKeyword_3());
             		
@@ -7264,22 +5099,22 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_LIST_OPEN_5, grammarAccess.getBooleanVariableAccess().getLIST_OPENTerminalRuleCall_5());
             		
-            // InternalTestgeneratorDSL.g:3119:3: ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )?
-            int alt76=2;
-            int LA76_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2174:3: ( ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )* )?
+            int alt35=2;
+            int LA35_0 = input.LA(1);
 
-            if ( ((LA76_0>=78 && LA76_0<=79)) ) {
-                alt76=1;
+            if ( ((LA35_0>=76 && LA35_0<=77)) ) {
+                alt35=1;
             }
-            switch (alt76) {
+            switch (alt35) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3120:4: ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )*
+                    // InternalTestgeneratorDSL.g:2175:4: ( (lv_proposals_6_0= ruleBoolean ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3120:4: ( (lv_proposals_6_0= ruleBoolean ) )
-                    // InternalTestgeneratorDSL.g:3121:5: (lv_proposals_6_0= ruleBoolean )
+                    // InternalTestgeneratorDSL.g:2175:4: ( (lv_proposals_6_0= ruleBoolean ) )
+                    // InternalTestgeneratorDSL.g:2176:5: (lv_proposals_6_0= ruleBoolean )
                     {
-                    // InternalTestgeneratorDSL.g:3121:5: (lv_proposals_6_0= ruleBoolean )
-                    // InternalTestgeneratorDSL.g:3122:6: lv_proposals_6_0= ruleBoolean
+                    // InternalTestgeneratorDSL.g:2176:5: (lv_proposals_6_0= ruleBoolean )
+                    // InternalTestgeneratorDSL.g:2177:6: lv_proposals_6_0= ruleBoolean
                     {
 
                     						newCompositeNode(grammarAccess.getBooleanVariableAccess().getProposalsBooleanEnumRuleCall_6_0_0());
@@ -7306,30 +5141,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3139:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )*
-                    loop75:
+                    // InternalTestgeneratorDSL.g:2194:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) ) )*
+                    loop34:
                     do {
-                        int alt75=2;
-                        int LA75_0 = input.LA(1);
+                        int alt34=2;
+                        int LA34_0 = input.LA(1);
 
-                        if ( (LA75_0==RULE_SEPARATOR) ) {
-                            alt75=1;
+                        if ( (LA34_0==RULE_SEPARATOR) ) {
+                            alt34=1;
                         }
 
 
-                        switch (alt75) {
+                        switch (alt34) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3140:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) )
+                    	    // InternalTestgeneratorDSL.g:2195:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_proposals_8_0= ruleBoolean ) )
                     	    {
                     	    this_SEPARATOR_7=(Token)match(input,RULE_SEPARATOR,FOLLOW_44); 
 
                     	    					newLeafNode(this_SEPARATOR_7, grammarAccess.getBooleanVariableAccess().getSEPARATORTerminalRuleCall_6_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3144:5: ( (lv_proposals_8_0= ruleBoolean ) )
-                    	    // InternalTestgeneratorDSL.g:3145:6: (lv_proposals_8_0= ruleBoolean )
+                    	    // InternalTestgeneratorDSL.g:2199:5: ( (lv_proposals_8_0= ruleBoolean ) )
+                    	    // InternalTestgeneratorDSL.g:2200:6: (lv_proposals_8_0= ruleBoolean )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3145:6: (lv_proposals_8_0= ruleBoolean )
-                    	    // InternalTestgeneratorDSL.g:3146:7: lv_proposals_8_0= ruleBoolean
+                    	    // InternalTestgeneratorDSL.g:2200:6: (lv_proposals_8_0= ruleBoolean )
+                    	    // InternalTestgeneratorDSL.g:2201:7: lv_proposals_8_0= ruleBoolean
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getBooleanVariableAccess().getProposalsBooleanEnumRuleCall_6_1_1_0());
@@ -7361,7 +5196,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop75;
+                    	    break loop34;
                         }
                     } while (true);
 
@@ -7402,7 +5237,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleLoop"
-    // InternalTestgeneratorDSL.g:3177:1: entryRuleLoop returns [EObject current=null] : iv_ruleLoop= ruleLoop EOF ;
+    // InternalTestgeneratorDSL.g:2232:1: entryRuleLoop returns [EObject current=null] : iv_ruleLoop= ruleLoop EOF ;
     public final EObject entryRuleLoop() throws RecognitionException {
         EObject current = null;
 
@@ -7410,8 +5245,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3177:45: (iv_ruleLoop= ruleLoop EOF )
-            // InternalTestgeneratorDSL.g:3178:2: iv_ruleLoop= ruleLoop EOF
+            // InternalTestgeneratorDSL.g:2232:45: (iv_ruleLoop= ruleLoop EOF )
+            // InternalTestgeneratorDSL.g:2233:2: iv_ruleLoop= ruleLoop EOF
             {
              newCompositeNode(grammarAccess.getLoopRule()); 
             pushFollow(FOLLOW_1);
@@ -7438,7 +5273,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleLoop"
-    // InternalTestgeneratorDSL.g:3184:1: ruleLoop returns [EObject current=null] : (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2239:1: ruleLoop returns [EObject current=null] : (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleLoop() throws RecognitionException {
         EObject current = null;
 
@@ -7469,21 +5304,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3190:2: ( (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3191:2: (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2245:2: ( (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2246:2: (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3191:2: (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3192:3: otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2246:2: (otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2247:3: otherlv_0= 'Loop' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'starts' otherlv_3= 'with' ( (lv_start_4_0= RULE_STRING ) ) otherlv_5= 'follows' otherlv_6= 'by' ( (lv_follower_7_0= RULE_STRING ) ) otherlv_8= 'ends' otherlv_9= 'with' ( (lv_end_10_0= RULE_STRING ) ) otherlv_11= 'has' otherlv_12= 'complexity' ( (lv_complexity_13_0= RULE_INT ) ) otherlv_14= 'passed' this_ASSOCIATION_15= RULE_ASSOCIATION this_LIST_OPEN_16= RULE_LIST_OPEN ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )? this_LIST_CLOSED_20= RULE_LIST_CLOSED this_DECLARATION_FINISHED_21= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,49,FOLLOW_4); 
+            otherlv_0=(Token)match(input,47,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getLoopAccess().getLoopKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:3196:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:3197:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2251:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2252:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:3197:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:3198:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2252:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2253:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_45); 
 
@@ -7505,7 +5340,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_2=(Token)match(input,50,FOLLOW_5); 
+            otherlv_2=(Token)match(input,48,FOLLOW_5); 
 
             			newLeafNode(otherlv_2, grammarAccess.getLoopAccess().getStartsKeyword_2());
             		
@@ -7513,11 +5348,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_3, grammarAccess.getLoopAccess().getWithKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:3222:3: ( (lv_start_4_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:3223:4: (lv_start_4_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2277:3: ( (lv_start_4_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:2278:4: (lv_start_4_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:3223:4: (lv_start_4_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:3224:5: lv_start_4_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:2278:4: (lv_start_4_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2279:5: lv_start_4_0= RULE_STRING
             {
             lv_start_4_0=(Token)match(input,RULE_STRING,FOLLOW_46); 
 
@@ -7539,19 +5374,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_5=(Token)match(input,51,FOLLOW_47); 
+            otherlv_5=(Token)match(input,49,FOLLOW_47); 
 
             			newLeafNode(otherlv_5, grammarAccess.getLoopAccess().getFollowsKeyword_5());
             		
-            otherlv_6=(Token)match(input,52,FOLLOW_7); 
+            otherlv_6=(Token)match(input,50,FOLLOW_7); 
 
             			newLeafNode(otherlv_6, grammarAccess.getLoopAccess().getByKeyword_6());
             		
-            // InternalTestgeneratorDSL.g:3248:3: ( (lv_follower_7_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:3249:4: (lv_follower_7_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2303:3: ( (lv_follower_7_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:2304:4: (lv_follower_7_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:3249:4: (lv_follower_7_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:3250:5: lv_follower_7_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:2304:4: (lv_follower_7_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2305:5: lv_follower_7_0= RULE_STRING
             {
             lv_follower_7_0=(Token)match(input,RULE_STRING,FOLLOW_48); 
 
@@ -7573,7 +5408,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_8=(Token)match(input,53,FOLLOW_5); 
+            otherlv_8=(Token)match(input,51,FOLLOW_5); 
 
             			newLeafNode(otherlv_8, grammarAccess.getLoopAccess().getEndsKeyword_8());
             		
@@ -7581,11 +5416,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(otherlv_9, grammarAccess.getLoopAccess().getWithKeyword_9());
             		
-            // InternalTestgeneratorDSL.g:3274:3: ( (lv_end_10_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:3275:4: (lv_end_10_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2329:3: ( (lv_end_10_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:2330:4: (lv_end_10_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:3275:4: (lv_end_10_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:3276:5: lv_end_10_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:2330:4: (lv_end_10_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:2331:5: lv_end_10_0= RULE_STRING
             {
             lv_end_10_0=(Token)match(input,RULE_STRING,FOLLOW_49); 
 
@@ -7607,19 +5442,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_11=(Token)match(input,54,FOLLOW_50); 
+            otherlv_11=(Token)match(input,52,FOLLOW_50); 
 
             			newLeafNode(otherlv_11, grammarAccess.getLoopAccess().getHasKeyword_11());
             		
-            otherlv_12=(Token)match(input,55,FOLLOW_42); 
+            otherlv_12=(Token)match(input,53,FOLLOW_42); 
 
             			newLeafNode(otherlv_12, grammarAccess.getLoopAccess().getComplexityKeyword_12());
             		
-            // InternalTestgeneratorDSL.g:3300:3: ( (lv_complexity_13_0= RULE_INT ) )
-            // InternalTestgeneratorDSL.g:3301:4: (lv_complexity_13_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:2355:3: ( (lv_complexity_13_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:2356:4: (lv_complexity_13_0= RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:3301:4: (lv_complexity_13_0= RULE_INT )
-            // InternalTestgeneratorDSL.g:3302:5: lv_complexity_13_0= RULE_INT
+            // InternalTestgeneratorDSL.g:2356:4: (lv_complexity_13_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:2357:5: lv_complexity_13_0= RULE_INT
             {
             lv_complexity_13_0=(Token)match(input,RULE_INT,FOLLOW_51); 
 
@@ -7641,7 +5476,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_14=(Token)match(input,56,FOLLOW_12); 
+            otherlv_14=(Token)match(input,54,FOLLOW_12); 
 
             			newLeafNode(otherlv_14, grammarAccess.getLoopAccess().getPassedKeyword_14());
             		
@@ -7653,22 +5488,22 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_LIST_OPEN_16, grammarAccess.getLoopAccess().getLIST_OPENTerminalRuleCall_16());
             		
-            // InternalTestgeneratorDSL.g:3330:3: ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )?
-            int alt78=2;
-            int LA78_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2385:3: ( ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )* )?
+            int alt37=2;
+            int LA37_0 = input.LA(1);
 
-            if ( (LA78_0==RULE_INT) ) {
-                alt78=1;
+            if ( (LA37_0==RULE_INT) ) {
+                alt37=1;
             }
-            switch (alt78) {
+            switch (alt37) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3331:4: ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )*
+                    // InternalTestgeneratorDSL.g:2386:4: ( (lv_frequencies_17_0= RULE_INT ) ) (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3331:4: ( (lv_frequencies_17_0= RULE_INT ) )
-                    // InternalTestgeneratorDSL.g:3332:5: (lv_frequencies_17_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2386:4: ( (lv_frequencies_17_0= RULE_INT ) )
+                    // InternalTestgeneratorDSL.g:2387:5: (lv_frequencies_17_0= RULE_INT )
                     {
-                    // InternalTestgeneratorDSL.g:3332:5: (lv_frequencies_17_0= RULE_INT )
-                    // InternalTestgeneratorDSL.g:3333:6: lv_frequencies_17_0= RULE_INT
+                    // InternalTestgeneratorDSL.g:2387:5: (lv_frequencies_17_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2388:6: lv_frequencies_17_0= RULE_INT
                     {
                     lv_frequencies_17_0=(Token)match(input,RULE_INT,FOLLOW_15); 
 
@@ -7690,30 +5525,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3349:4: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )*
-                    loop77:
+                    // InternalTestgeneratorDSL.g:2404:4: (this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) ) )*
+                    loop36:
                     do {
-                        int alt77=2;
-                        int LA77_0 = input.LA(1);
+                        int alt36=2;
+                        int LA36_0 = input.LA(1);
 
-                        if ( (LA77_0==RULE_SEPARATOR) ) {
-                            alt77=1;
+                        if ( (LA36_0==RULE_SEPARATOR) ) {
+                            alt36=1;
                         }
 
 
-                        switch (alt77) {
+                        switch (alt36) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3350:5: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) )
+                    	    // InternalTestgeneratorDSL.g:2405:5: this_SEPARATOR_18= RULE_SEPARATOR ( (lv_frequencies_19_0= RULE_INT ) )
                     	    {
                     	    this_SEPARATOR_18=(Token)match(input,RULE_SEPARATOR,FOLLOW_42); 
 
                     	    					newLeafNode(this_SEPARATOR_18, grammarAccess.getLoopAccess().getSEPARATORTerminalRuleCall_17_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3354:5: ( (lv_frequencies_19_0= RULE_INT ) )
-                    	    // InternalTestgeneratorDSL.g:3355:6: (lv_frequencies_19_0= RULE_INT )
+                    	    // InternalTestgeneratorDSL.g:2409:5: ( (lv_frequencies_19_0= RULE_INT ) )
+                    	    // InternalTestgeneratorDSL.g:2410:6: (lv_frequencies_19_0= RULE_INT )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3355:6: (lv_frequencies_19_0= RULE_INT )
-                    	    // InternalTestgeneratorDSL.g:3356:7: lv_frequencies_19_0= RULE_INT
+                    	    // InternalTestgeneratorDSL.g:2410:6: (lv_frequencies_19_0= RULE_INT )
+                    	    // InternalTestgeneratorDSL.g:2411:7: lv_frequencies_19_0= RULE_INT
                     	    {
                     	    lv_frequencies_19_0=(Token)match(input,RULE_INT,FOLLOW_15); 
 
@@ -7740,7 +5575,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop77;
+                    	    break loop36;
                         }
                     } while (true);
 
@@ -7781,7 +5616,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleFlow"
-    // InternalTestgeneratorDSL.g:3386:1: entryRuleFlow returns [EObject current=null] : iv_ruleFlow= ruleFlow EOF ;
+    // InternalTestgeneratorDSL.g:2441:1: entryRuleFlow returns [EObject current=null] : iv_ruleFlow= ruleFlow EOF ;
     public final EObject entryRuleFlow() throws RecognitionException {
         EObject current = null;
 
@@ -7789,8 +5624,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3386:45: (iv_ruleFlow= ruleFlow EOF )
-            // InternalTestgeneratorDSL.g:3387:2: iv_ruleFlow= ruleFlow EOF
+            // InternalTestgeneratorDSL.g:2441:45: (iv_ruleFlow= ruleFlow EOF )
+            // InternalTestgeneratorDSL.g:2442:2: iv_ruleFlow= ruleFlow EOF
             {
              newCompositeNode(grammarAccess.getFlowRule()); 
             pushFollow(FOLLOW_1);
@@ -7817,7 +5652,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleFlow"
-    // InternalTestgeneratorDSL.g:3393:1: ruleFlow returns [EObject current=null] : (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2448:1: ruleFlow returns [EObject current=null] : (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleFlow() throws RecognitionException {
         EObject current = null;
 
@@ -7857,21 +5692,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3399:2: ( (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3400:2: (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2454:2: ( (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2455:2: (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3400:2: (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3401:3: otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2455:2: (otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2456:3: otherlv_0= 'Flow' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_bpmnReference_3_0= ruleBPMNReference ) ) (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )? otherlv_8= 'with' otherlv_9= 'elements' this_ASSOCIATION_10= RULE_ASSOCIATION this_LIST_OPEN_11= RULE_LIST_OPEN ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_15= RULE_LIST_CLOSED (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_24= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,57,FOLLOW_4); 
+            otherlv_0=(Token)match(input,55,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getFlowAccess().getFlowKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:3405:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:3406:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2460:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2461:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:3406:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:3407:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2461:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2462:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_52); 
 
@@ -7893,15 +5728,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_2=(Token)match(input,58,FOLLOW_4); 
+            otherlv_2=(Token)match(input,56,FOLLOW_4); 
 
             			newLeafNode(otherlv_2, grammarAccess.getFlowAccess().getForKeyword_2());
             		
-            // InternalTestgeneratorDSL.g:3427:3: ( (lv_bpmnReference_3_0= ruleBPMNReference ) )
-            // InternalTestgeneratorDSL.g:3428:4: (lv_bpmnReference_3_0= ruleBPMNReference )
+            // InternalTestgeneratorDSL.g:2482:3: ( (lv_bpmnReference_3_0= ruleBPMNReference ) )
+            // InternalTestgeneratorDSL.g:2483:4: (lv_bpmnReference_3_0= ruleBPMNReference )
             {
-            // InternalTestgeneratorDSL.g:3428:4: (lv_bpmnReference_3_0= ruleBPMNReference )
-            // InternalTestgeneratorDSL.g:3429:5: lv_bpmnReference_3_0= ruleBPMNReference
+            // InternalTestgeneratorDSL.g:2483:4: (lv_bpmnReference_3_0= ruleBPMNReference )
+            // InternalTestgeneratorDSL.g:2484:5: lv_bpmnReference_3_0= ruleBPMNReference
             {
 
             					newCompositeNode(grammarAccess.getFlowAccess().getBpmnReferenceBPMNReferenceParserRuleCall_3_0());
@@ -7928,38 +5763,38 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:3446:3: (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )?
-            int alt79=2;
-            int LA79_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2501:3: (otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) ) )?
+            int alt38=2;
+            int LA38_0 = input.LA(1);
 
-            if ( (LA79_0==17) ) {
-                int LA79_1 = input.LA(2);
+            if ( (LA38_0==17) ) {
+                int LA38_1 = input.LA(2);
 
-                if ( (LA79_1==59) ) {
-                    alt79=1;
+                if ( (LA38_1==57) ) {
+                    alt38=1;
                 }
             }
-            switch (alt79) {
+            switch (alt38) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3447:4: otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) )
+                    // InternalTestgeneratorDSL.g:2502:4: otherlv_4= 'with' otherlv_5= 'flag' this_ASSOCIATION_6= RULE_ASSOCIATION ( (lv_flag_7_0= ruleFlag ) )
                     {
                     otherlv_4=(Token)match(input,17,FOLLOW_53); 
 
                     				newLeafNode(otherlv_4, grammarAccess.getFlowAccess().getWithKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,59,FOLLOW_12); 
+                    otherlv_5=(Token)match(input,57,FOLLOW_12); 
 
                     				newLeafNode(otherlv_5, grammarAccess.getFlowAccess().getFlagKeyword_4_1());
                     			
-                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_54); 
+                    this_ASSOCIATION_6=(Token)match(input,RULE_ASSOCIATION,FOLLOW_39); 
 
                     				newLeafNode(this_ASSOCIATION_6, grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_4_2());
                     			
-                    // InternalTestgeneratorDSL.g:3459:4: ( (lv_flag_7_0= ruleFlag ) )
-                    // InternalTestgeneratorDSL.g:3460:5: (lv_flag_7_0= ruleFlag )
+                    // InternalTestgeneratorDSL.g:2514:4: ( (lv_flag_7_0= ruleFlag ) )
+                    // InternalTestgeneratorDSL.g:2515:5: (lv_flag_7_0= ruleFlag )
                     {
-                    // InternalTestgeneratorDSL.g:3460:5: (lv_flag_7_0= ruleFlag )
-                    // InternalTestgeneratorDSL.g:3461:6: lv_flag_7_0= ruleFlag
+                    // InternalTestgeneratorDSL.g:2515:5: (lv_flag_7_0= ruleFlag )
+                    // InternalTestgeneratorDSL.g:2516:6: lv_flag_7_0= ruleFlag
                     {
 
                     						newCompositeNode(grammarAccess.getFlowAccess().getFlagFlagEnumRuleCall_4_3_0());
@@ -7992,11 +5827,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_8=(Token)match(input,17,FOLLOW_55); 
+            otherlv_8=(Token)match(input,17,FOLLOW_54); 
 
             			newLeafNode(otherlv_8, grammarAccess.getFlowAccess().getWithKeyword_5());
             		
-            otherlv_9=(Token)match(input,60,FOLLOW_12); 
+            otherlv_9=(Token)match(input,58,FOLLOW_12); 
 
             			newLeafNode(otherlv_9, grammarAccess.getFlowAccess().getElementsKeyword_6());
             		
@@ -8004,26 +5839,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_ASSOCIATION_10, grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_7());
             		
-            this_LIST_OPEN_11=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+            this_LIST_OPEN_11=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
             			newLeafNode(this_LIST_OPEN_11, grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_8());
             		
-            // InternalTestgeneratorDSL.g:3495:3: ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )?
-            int alt81=2;
-            int LA81_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2550:3: ( ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )* )?
+            int alt40=2;
+            int LA40_0 = input.LA(1);
 
-            if ( (LA81_0==RULE_ID) ) {
-                alt81=1;
+            if ( (LA40_0==RULE_ID) ) {
+                alt40=1;
             }
-            switch (alt81) {
+            switch (alt40) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3496:4: ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )*
+                    // InternalTestgeneratorDSL.g:2551:4: ( (lv_inclElements_12_0= ruleFlowElementReference ) ) (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3496:4: ( (lv_inclElements_12_0= ruleFlowElementReference ) )
-                    // InternalTestgeneratorDSL.g:3497:5: (lv_inclElements_12_0= ruleFlowElementReference )
+                    // InternalTestgeneratorDSL.g:2551:4: ( (lv_inclElements_12_0= ruleFlowElementReference ) )
+                    // InternalTestgeneratorDSL.g:2552:5: (lv_inclElements_12_0= ruleFlowElementReference )
                     {
-                    // InternalTestgeneratorDSL.g:3497:5: (lv_inclElements_12_0= ruleFlowElementReference )
-                    // InternalTestgeneratorDSL.g:3498:6: lv_inclElements_12_0= ruleFlowElementReference
+                    // InternalTestgeneratorDSL.g:2552:5: (lv_inclElements_12_0= ruleFlowElementReference )
+                    // InternalTestgeneratorDSL.g:2553:6: lv_inclElements_12_0= ruleFlowElementReference
                     {
 
                     						newCompositeNode(grammarAccess.getFlowAccess().getInclElementsFlowElementReferenceParserRuleCall_9_0_0());
@@ -8050,30 +5885,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3515:4: (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )*
-                    loop80:
+                    // InternalTestgeneratorDSL.g:2570:4: (this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) ) )*
+                    loop39:
                     do {
-                        int alt80=2;
-                        int LA80_0 = input.LA(1);
+                        int alt39=2;
+                        int LA39_0 = input.LA(1);
 
-                        if ( (LA80_0==RULE_SEPARATOR) ) {
-                            alt80=1;
+                        if ( (LA39_0==RULE_SEPARATOR) ) {
+                            alt39=1;
                         }
 
 
-                        switch (alt80) {
+                        switch (alt39) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3516:5: this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) )
+                    	    // InternalTestgeneratorDSL.g:2571:5: this_SEPARATOR_13= RULE_SEPARATOR ( (lv_inclElements_14_0= ruleFlowElementReference ) )
                     	    {
                     	    this_SEPARATOR_13=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                     	    					newLeafNode(this_SEPARATOR_13, grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_9_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3520:5: ( (lv_inclElements_14_0= ruleFlowElementReference ) )
-                    	    // InternalTestgeneratorDSL.g:3521:6: (lv_inclElements_14_0= ruleFlowElementReference )
+                    	    // InternalTestgeneratorDSL.g:2575:5: ( (lv_inclElements_14_0= ruleFlowElementReference ) )
+                    	    // InternalTestgeneratorDSL.g:2576:6: (lv_inclElements_14_0= ruleFlowElementReference )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3521:6: (lv_inclElements_14_0= ruleFlowElementReference )
-                    	    // InternalTestgeneratorDSL.g:3522:7: lv_inclElements_14_0= ruleFlowElementReference
+                    	    // InternalTestgeneratorDSL.g:2576:6: (lv_inclElements_14_0= ruleFlowElementReference )
+                    	    // InternalTestgeneratorDSL.g:2577:7: lv_inclElements_14_0= ruleFlowElementReference
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getFlowAccess().getInclElementsFlowElementReferenceParserRuleCall_9_1_1_0());
@@ -8105,7 +5940,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop80;
+                    	    break loop39;
                         }
                     } while (true);
 
@@ -8115,26 +5950,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_LIST_CLOSED_15=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_56); 
+            this_LIST_CLOSED_15=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_55); 
 
             			newLeafNode(this_LIST_CLOSED_15, grammarAccess.getFlowAccess().getLIST_CLOSEDTerminalRuleCall_10());
             		
-            // InternalTestgeneratorDSL.g:3545:3: (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )?
-            int alt84=2;
-            int LA84_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2600:3: (otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED )?
+            int alt43=2;
+            int LA43_0 = input.LA(1);
 
-            if ( (LA84_0==61) ) {
-                alt84=1;
+            if ( (LA43_0==59) ) {
+                alt43=1;
             }
-            switch (alt84) {
+            switch (alt43) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3546:4: otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:2601:4: otherlv_16= 'without' otherlv_17= 'elements' this_ASSOCIATION_18= RULE_ASSOCIATION this_LIST_OPEN_19= RULE_LIST_OPEN ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )? this_LIST_CLOSED_23= RULE_LIST_CLOSED
                     {
-                    otherlv_16=(Token)match(input,61,FOLLOW_55); 
+                    otherlv_16=(Token)match(input,59,FOLLOW_54); 
 
                     				newLeafNode(otherlv_16, grammarAccess.getFlowAccess().getWithoutKeyword_11_0());
                     			
-                    otherlv_17=(Token)match(input,60,FOLLOW_12); 
+                    otherlv_17=(Token)match(input,58,FOLLOW_12); 
 
                     				newLeafNode(otherlv_17, grammarAccess.getFlowAccess().getElementsKeyword_11_1());
                     			
@@ -8142,26 +5977,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     				newLeafNode(this_ASSOCIATION_18, grammarAccess.getFlowAccess().getASSOCIATIONTerminalRuleCall_11_2());
                     			
-                    this_LIST_OPEN_19=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_LIST_OPEN_19=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
                     				newLeafNode(this_LIST_OPEN_19, grammarAccess.getFlowAccess().getLIST_OPENTerminalRuleCall_11_3());
                     			
-                    // InternalTestgeneratorDSL.g:3562:4: ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )?
-                    int alt83=2;
-                    int LA83_0 = input.LA(1);
+                    // InternalTestgeneratorDSL.g:2617:4: ( ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )* )?
+                    int alt42=2;
+                    int LA42_0 = input.LA(1);
 
-                    if ( (LA83_0==RULE_ID) ) {
-                        alt83=1;
+                    if ( (LA42_0==RULE_ID) ) {
+                        alt42=1;
                     }
-                    switch (alt83) {
+                    switch (alt42) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:3563:5: ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )*
+                            // InternalTestgeneratorDSL.g:2618:5: ( (lv_exclElements_20_0= ruleFlowElementReference ) ) (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )*
                             {
-                            // InternalTestgeneratorDSL.g:3563:5: ( (lv_exclElements_20_0= ruleFlowElementReference ) )
-                            // InternalTestgeneratorDSL.g:3564:6: (lv_exclElements_20_0= ruleFlowElementReference )
+                            // InternalTestgeneratorDSL.g:2618:5: ( (lv_exclElements_20_0= ruleFlowElementReference ) )
+                            // InternalTestgeneratorDSL.g:2619:6: (lv_exclElements_20_0= ruleFlowElementReference )
                             {
-                            // InternalTestgeneratorDSL.g:3564:6: (lv_exclElements_20_0= ruleFlowElementReference )
-                            // InternalTestgeneratorDSL.g:3565:7: lv_exclElements_20_0= ruleFlowElementReference
+                            // InternalTestgeneratorDSL.g:2619:6: (lv_exclElements_20_0= ruleFlowElementReference )
+                            // InternalTestgeneratorDSL.g:2620:7: lv_exclElements_20_0= ruleFlowElementReference
                             {
 
                             							newCompositeNode(grammarAccess.getFlowAccess().getExclElementsFlowElementReferenceParserRuleCall_11_4_0_0());
@@ -8188,30 +6023,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                             }
 
-                            // InternalTestgeneratorDSL.g:3582:5: (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )*
-                            loop82:
+                            // InternalTestgeneratorDSL.g:2637:5: (this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) ) )*
+                            loop41:
                             do {
-                                int alt82=2;
-                                int LA82_0 = input.LA(1);
+                                int alt41=2;
+                                int LA41_0 = input.LA(1);
 
-                                if ( (LA82_0==RULE_SEPARATOR) ) {
-                                    alt82=1;
+                                if ( (LA41_0==RULE_SEPARATOR) ) {
+                                    alt41=1;
                                 }
 
 
-                                switch (alt82) {
+                                switch (alt41) {
                             	case 1 :
-                            	    // InternalTestgeneratorDSL.g:3583:6: this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) )
+                            	    // InternalTestgeneratorDSL.g:2638:6: this_SEPARATOR_21= RULE_SEPARATOR ( (lv_exclElements_22_0= ruleFlowElementReference ) )
                             	    {
                             	    this_SEPARATOR_21=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                             	    						newLeafNode(this_SEPARATOR_21, grammarAccess.getFlowAccess().getSEPARATORTerminalRuleCall_11_4_1_0());
                             	    					
-                            	    // InternalTestgeneratorDSL.g:3587:6: ( (lv_exclElements_22_0= ruleFlowElementReference ) )
-                            	    // InternalTestgeneratorDSL.g:3588:7: (lv_exclElements_22_0= ruleFlowElementReference )
+                            	    // InternalTestgeneratorDSL.g:2642:6: ( (lv_exclElements_22_0= ruleFlowElementReference ) )
+                            	    // InternalTestgeneratorDSL.g:2643:7: (lv_exclElements_22_0= ruleFlowElementReference )
                             	    {
-                            	    // InternalTestgeneratorDSL.g:3588:7: (lv_exclElements_22_0= ruleFlowElementReference )
-                            	    // InternalTestgeneratorDSL.g:3589:8: lv_exclElements_22_0= ruleFlowElementReference
+                            	    // InternalTestgeneratorDSL.g:2643:7: (lv_exclElements_22_0= ruleFlowElementReference )
+                            	    // InternalTestgeneratorDSL.g:2644:8: lv_exclElements_22_0= ruleFlowElementReference
                             	    {
 
                             	    								newCompositeNode(grammarAccess.getFlowAccess().getExclElementsFlowElementReferenceParserRuleCall_11_4_1_1_0());
@@ -8243,7 +6078,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    break;
 
                             	default :
-                            	    break loop82;
+                            	    break loop41;
                                 }
                             } while (true);
 
@@ -8290,7 +6125,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleFlowReference"
-    // InternalTestgeneratorDSL.g:3621:1: entryRuleFlowReference returns [EObject current=null] : iv_ruleFlowReference= ruleFlowReference EOF ;
+    // InternalTestgeneratorDSL.g:2676:1: entryRuleFlowReference returns [EObject current=null] : iv_ruleFlowReference= ruleFlowReference EOF ;
     public final EObject entryRuleFlowReference() throws RecognitionException {
         EObject current = null;
 
@@ -8298,8 +6133,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3621:54: (iv_ruleFlowReference= ruleFlowReference EOF )
-            // InternalTestgeneratorDSL.g:3622:2: iv_ruleFlowReference= ruleFlowReference EOF
+            // InternalTestgeneratorDSL.g:2676:54: (iv_ruleFlowReference= ruleFlowReference EOF )
+            // InternalTestgeneratorDSL.g:2677:2: iv_ruleFlowReference= ruleFlowReference EOF
             {
              newCompositeNode(grammarAccess.getFlowReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -8326,7 +6161,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleFlowReference"
-    // InternalTestgeneratorDSL.g:3628:1: ruleFlowReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:2683:1: ruleFlowReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
     public final EObject ruleFlowReference() throws RecognitionException {
         EObject current = null;
 
@@ -8336,14 +6171,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3634:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:3635:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2689:2: ( ( (otherlv_0= RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:2690:2: ( (otherlv_0= RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:3635:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:3636:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2690:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2691:3: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:3636:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:3637:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2691:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2692:4: otherlv_0= RULE_ID
             {
 
             				if (current==null) {
@@ -8380,7 +6215,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleTest"
-    // InternalTestgeneratorDSL.g:3651:1: entryRuleTest returns [EObject current=null] : iv_ruleTest= ruleTest EOF ;
+    // InternalTestgeneratorDSL.g:2706:1: entryRuleTest returns [EObject current=null] : iv_ruleTest= ruleTest EOF ;
     public final EObject entryRuleTest() throws RecognitionException {
         EObject current = null;
 
@@ -8388,8 +6223,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3651:45: (iv_ruleTest= ruleTest EOF )
-            // InternalTestgeneratorDSL.g:3652:2: iv_ruleTest= ruleTest EOF
+            // InternalTestgeneratorDSL.g:2706:45: (iv_ruleTest= ruleTest EOF )
+            // InternalTestgeneratorDSL.g:2707:2: iv_ruleTest= ruleTest EOF
             {
              newCompositeNode(grammarAccess.getTestRule()); 
             pushFollow(FOLLOW_1);
@@ -8416,7 +6251,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleTest"
-    // InternalTestgeneratorDSL.g:3658:1: ruleTest returns [EObject current=null] : (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:2713:1: ruleTest returns [EObject current=null] : (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleTest() throws RecognitionException {
         EObject current = null;
 
@@ -8451,21 +6286,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3664:2: ( (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:3665:2: (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2719:2: ( (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:2720:2: (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:3665:2: (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:3666:3: otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:2720:2: (otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:2721:3: otherlv_0= 'Test' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_flowReference_3_0= ruleFlowReference ) ) (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )? ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )? ( (lv_endCheck_10_0= ruleEndChecks ) )? (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )? this_DECLARATION_FINISHED_19= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,62,FOLLOW_4); 
+            otherlv_0=(Token)match(input,60,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getTestAccess().getTestKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:3670:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:3671:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2725:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:2726:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:3671:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:3672:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:2726:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:2727:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_52); 
 
@@ -8487,15 +6322,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_2=(Token)match(input,58,FOLLOW_4); 
+            otherlv_2=(Token)match(input,56,FOLLOW_4); 
 
             			newLeafNode(otherlv_2, grammarAccess.getTestAccess().getForKeyword_2());
             		
-            // InternalTestgeneratorDSL.g:3692:3: ( (lv_flowReference_3_0= ruleFlowReference ) )
-            // InternalTestgeneratorDSL.g:3693:4: (lv_flowReference_3_0= ruleFlowReference )
+            // InternalTestgeneratorDSL.g:2747:3: ( (lv_flowReference_3_0= ruleFlowReference ) )
+            // InternalTestgeneratorDSL.g:2748:4: (lv_flowReference_3_0= ruleFlowReference )
             {
-            // InternalTestgeneratorDSL.g:3693:4: (lv_flowReference_3_0= ruleFlowReference )
-            // InternalTestgeneratorDSL.g:3694:5: lv_flowReference_3_0= ruleFlowReference
+            // InternalTestgeneratorDSL.g:2748:4: (lv_flowReference_3_0= ruleFlowReference )
+            // InternalTestgeneratorDSL.g:2749:5: lv_flowReference_3_0= ruleFlowReference
             {
 
             					newCompositeNode(grammarAccess.getTestAccess().getFlowReferenceFlowReferenceParserRuleCall_3_0());
@@ -8522,34 +6357,34 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:3711:3: (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )?
-            int alt85=2;
-            int LA85_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2766:3: (otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) ) )?
+            int alt44=2;
+            int LA44_0 = input.LA(1);
 
-            if ( (LA85_0==17) ) {
-                int LA85_1 = input.LA(2);
+            if ( (LA44_0==17) ) {
+                int LA44_1 = input.LA(2);
 
-                if ( (LA85_1==63) ) {
-                    alt85=1;
+                if ( (LA44_1==61) ) {
+                    alt44=1;
                 }
             }
-            switch (alt85) {
+            switch (alt44) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3712:4: otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) )
+                    // InternalTestgeneratorDSL.g:2767:4: otherlv_4= 'with' otherlv_5= 'priority' ( (lv_priority_6_0= RULE_INT ) )
                     {
-                    otherlv_4=(Token)match(input,17,FOLLOW_57); 
+                    otherlv_4=(Token)match(input,17,FOLLOW_56); 
 
                     				newLeafNode(otherlv_4, grammarAccess.getTestAccess().getWithKeyword_4_0());
                     			
-                    otherlv_5=(Token)match(input,63,FOLLOW_42); 
+                    otherlv_5=(Token)match(input,61,FOLLOW_42); 
 
                     				newLeafNode(otherlv_5, grammarAccess.getTestAccess().getPriorityKeyword_4_1());
                     			
-                    // InternalTestgeneratorDSL.g:3720:4: ( (lv_priority_6_0= RULE_INT ) )
-                    // InternalTestgeneratorDSL.g:3721:5: (lv_priority_6_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2775:4: ( (lv_priority_6_0= RULE_INT ) )
+                    // InternalTestgeneratorDSL.g:2776:5: (lv_priority_6_0= RULE_INT )
                     {
-                    // InternalTestgeneratorDSL.g:3721:5: (lv_priority_6_0= RULE_INT )
-                    // InternalTestgeneratorDSL.g:3722:6: lv_priority_6_0= RULE_INT
+                    // InternalTestgeneratorDSL.g:2776:5: (lv_priority_6_0= RULE_INT )
+                    // InternalTestgeneratorDSL.g:2777:6: lv_priority_6_0= RULE_INT
                     {
                     lv_priority_6_0=(Token)match(input,RULE_INT,FOLLOW_10); 
 
@@ -8577,31 +6412,31 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:3739:3: ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )?
-            int alt87=2;
-            int LA87_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2794:3: ( ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )* )?
+            int alt46=2;
+            int LA46_0 = input.LA(1);
 
-            if ( (LA87_0==17) ) {
-                int LA87_1 = input.LA(2);
+            if ( (LA46_0==17) ) {
+                int LA46_1 = input.LA(2);
 
-                if ( (LA87_1==65) ) {
-                    alt87=1;
+                if ( (LA46_1==63) ) {
+                    alt46=1;
                 }
             }
-            switch (alt87) {
+            switch (alt46) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3740:4: ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )*
+                    // InternalTestgeneratorDSL.g:2795:4: ( (lv_declarations_7_0= ruleVariableDeclarations ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3740:4: ( (lv_declarations_7_0= ruleVariableDeclarations ) )
-                    // InternalTestgeneratorDSL.g:3741:5: (lv_declarations_7_0= ruleVariableDeclarations )
+                    // InternalTestgeneratorDSL.g:2795:4: ( (lv_declarations_7_0= ruleVariableDeclarations ) )
+                    // InternalTestgeneratorDSL.g:2796:5: (lv_declarations_7_0= ruleVariableDeclarations )
                     {
-                    // InternalTestgeneratorDSL.g:3741:5: (lv_declarations_7_0= ruleVariableDeclarations )
-                    // InternalTestgeneratorDSL.g:3742:6: lv_declarations_7_0= ruleVariableDeclarations
+                    // InternalTestgeneratorDSL.g:2796:5: (lv_declarations_7_0= ruleVariableDeclarations )
+                    // InternalTestgeneratorDSL.g:2797:6: lv_declarations_7_0= ruleVariableDeclarations
                     {
 
                     						newCompositeNode(grammarAccess.getTestAccess().getDeclarationsVariableDeclarationsParserRuleCall_5_0_0());
                     					
-                    pushFollow(FOLLOW_58);
+                    pushFollow(FOLLOW_57);
                     lv_declarations_7_0=ruleVariableDeclarations();
 
                     state._fsp--;
@@ -8623,35 +6458,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3759:4: (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )*
-                    loop86:
+                    // InternalTestgeneratorDSL.g:2814:4: (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) ) )*
+                    loop45:
                     do {
-                        int alt86=2;
-                        int LA86_0 = input.LA(1);
+                        int alt45=2;
+                        int LA45_0 = input.LA(1);
 
-                        if ( (LA86_0==RULE_SEPARATOR) ) {
-                            alt86=1;
+                        if ( (LA45_0==RULE_SEPARATOR) ) {
+                            alt45=1;
                         }
 
 
-                        switch (alt86) {
+                        switch (alt45) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3760:5: this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) )
+                    	    // InternalTestgeneratorDSL.g:2815:5: this_SEPARATOR_8= RULE_SEPARATOR ( (lv_declarations_9_0= ruleVariableDeclarations ) )
                     	    {
                     	    this_SEPARATOR_8=(Token)match(input,RULE_SEPARATOR,FOLLOW_5); 
 
                     	    					newLeafNode(this_SEPARATOR_8, grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_5_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3764:5: ( (lv_declarations_9_0= ruleVariableDeclarations ) )
-                    	    // InternalTestgeneratorDSL.g:3765:6: (lv_declarations_9_0= ruleVariableDeclarations )
+                    	    // InternalTestgeneratorDSL.g:2819:5: ( (lv_declarations_9_0= ruleVariableDeclarations ) )
+                    	    // InternalTestgeneratorDSL.g:2820:6: (lv_declarations_9_0= ruleVariableDeclarations )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3765:6: (lv_declarations_9_0= ruleVariableDeclarations )
-                    	    // InternalTestgeneratorDSL.g:3766:7: lv_declarations_9_0= ruleVariableDeclarations
+                    	    // InternalTestgeneratorDSL.g:2820:6: (lv_declarations_9_0= ruleVariableDeclarations )
+                    	    // InternalTestgeneratorDSL.g:2821:7: lv_declarations_9_0= ruleVariableDeclarations
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getTestAccess().getDeclarationsVariableDeclarationsParserRuleCall_5_1_1_0());
                     	    						
-                    	    pushFollow(FOLLOW_58);
+                    	    pushFollow(FOLLOW_57);
                     	    lv_declarations_9_0=ruleVariableDeclarations();
 
                     	    state._fsp--;
@@ -8678,7 +6513,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop86;
+                    	    break loop45;
                         }
                     } while (true);
 
@@ -8688,23 +6523,23 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:3785:3: ( (lv_endCheck_10_0= ruleEndChecks ) )?
-            int alt88=2;
-            int LA88_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2840:3: ( (lv_endCheck_10_0= ruleEndChecks ) )?
+            int alt47=2;
+            int LA47_0 = input.LA(1);
 
-            if ( (LA88_0==17) ) {
-                int LA88_1 = input.LA(2);
+            if ( (LA47_0==17) ) {
+                int LA47_1 = input.LA(2);
 
-                if ( (LA88_1==66) ) {
-                    alt88=1;
+                if ( (LA47_1==64) ) {
+                    alt47=1;
                 }
             }
-            switch (alt88) {
+            switch (alt47) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3786:4: (lv_endCheck_10_0= ruleEndChecks )
+                    // InternalTestgeneratorDSL.g:2841:4: (lv_endCheck_10_0= ruleEndChecks )
                     {
-                    // InternalTestgeneratorDSL.g:3786:4: (lv_endCheck_10_0= ruleEndChecks )
-                    // InternalTestgeneratorDSL.g:3787:5: lv_endCheck_10_0= ruleEndChecks
+                    // InternalTestgeneratorDSL.g:2841:4: (lv_endCheck_10_0= ruleEndChecks )
+                    // InternalTestgeneratorDSL.g:2842:5: lv_endCheck_10_0= ruleEndChecks
                     {
 
                     					newCompositeNode(grammarAccess.getTestAccess().getEndCheckEndChecksParserRuleCall_6_0());
@@ -8734,22 +6569,22 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:3804:3: (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )?
-            int alt91=2;
-            int LA91_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2859:3: (otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED )?
+            int alt50=2;
+            int LA50_0 = input.LA(1);
 
-            if ( (LA91_0==17) ) {
-                alt91=1;
+            if ( (LA50_0==17) ) {
+                alt50=1;
             }
-            switch (alt91) {
+            switch (alt50) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3805:4: otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED
+                    // InternalTestgeneratorDSL.g:2860:4: otherlv_11= 'with' otherlv_12= 'mocks' this_ASSOCIATION_13= RULE_ASSOCIATION this_LIST_OPEN_14= RULE_LIST_OPEN ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )? this_LIST_CLOSED_18= RULE_LIST_CLOSED
                     {
-                    otherlv_11=(Token)match(input,17,FOLLOW_59); 
+                    otherlv_11=(Token)match(input,17,FOLLOW_58); 
 
                     				newLeafNode(otherlv_11, grammarAccess.getTestAccess().getWithKeyword_7_0());
                     			
-                    otherlv_12=(Token)match(input,64,FOLLOW_12); 
+                    otherlv_12=(Token)match(input,62,FOLLOW_12); 
 
                     				newLeafNode(otherlv_12, grammarAccess.getTestAccess().getMocksKeyword_7_1());
                     			
@@ -8757,26 +6592,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     				newLeafNode(this_ASSOCIATION_13, grammarAccess.getTestAccess().getASSOCIATIONTerminalRuleCall_7_2());
                     			
-                    this_LIST_OPEN_14=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+                    this_LIST_OPEN_14=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
                     				newLeafNode(this_LIST_OPEN_14, grammarAccess.getTestAccess().getLIST_OPENTerminalRuleCall_7_3());
                     			
-                    // InternalTestgeneratorDSL.g:3821:4: ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )?
-                    int alt90=2;
-                    int LA90_0 = input.LA(1);
+                    // InternalTestgeneratorDSL.g:2876:4: ( ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )* )?
+                    int alt49=2;
+                    int LA49_0 = input.LA(1);
 
-                    if ( (LA90_0==RULE_ID) ) {
-                        alt90=1;
+                    if ( (LA49_0==RULE_ID) ) {
+                        alt49=1;
                     }
-                    switch (alt90) {
+                    switch (alt49) {
                         case 1 :
-                            // InternalTestgeneratorDSL.g:3822:5: ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )*
+                            // InternalTestgeneratorDSL.g:2877:5: ( (lv_mocks_15_0= ruleMockReference ) ) (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )*
                             {
-                            // InternalTestgeneratorDSL.g:3822:5: ( (lv_mocks_15_0= ruleMockReference ) )
-                            // InternalTestgeneratorDSL.g:3823:6: (lv_mocks_15_0= ruleMockReference )
+                            // InternalTestgeneratorDSL.g:2877:5: ( (lv_mocks_15_0= ruleMockReference ) )
+                            // InternalTestgeneratorDSL.g:2878:6: (lv_mocks_15_0= ruleMockReference )
                             {
-                            // InternalTestgeneratorDSL.g:3823:6: (lv_mocks_15_0= ruleMockReference )
-                            // InternalTestgeneratorDSL.g:3824:7: lv_mocks_15_0= ruleMockReference
+                            // InternalTestgeneratorDSL.g:2878:6: (lv_mocks_15_0= ruleMockReference )
+                            // InternalTestgeneratorDSL.g:2879:7: lv_mocks_15_0= ruleMockReference
                             {
 
                             							newCompositeNode(grammarAccess.getTestAccess().getMocksMockReferenceParserRuleCall_7_4_0_0());
@@ -8803,30 +6638,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                             }
 
-                            // InternalTestgeneratorDSL.g:3841:5: (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )*
-                            loop89:
+                            // InternalTestgeneratorDSL.g:2896:5: (this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) ) )*
+                            loop48:
                             do {
-                                int alt89=2;
-                                int LA89_0 = input.LA(1);
+                                int alt48=2;
+                                int LA48_0 = input.LA(1);
 
-                                if ( (LA89_0==RULE_SEPARATOR) ) {
-                                    alt89=1;
+                                if ( (LA48_0==RULE_SEPARATOR) ) {
+                                    alt48=1;
                                 }
 
 
-                                switch (alt89) {
+                                switch (alt48) {
                             	case 1 :
-                            	    // InternalTestgeneratorDSL.g:3842:6: this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) )
+                            	    // InternalTestgeneratorDSL.g:2897:6: this_SEPARATOR_16= RULE_SEPARATOR ( (lv_mocks_17_0= ruleMockReference ) )
                             	    {
                             	    this_SEPARATOR_16=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                             	    						newLeafNode(this_SEPARATOR_16, grammarAccess.getTestAccess().getSEPARATORTerminalRuleCall_7_4_1_0());
                             	    					
-                            	    // InternalTestgeneratorDSL.g:3846:6: ( (lv_mocks_17_0= ruleMockReference ) )
-                            	    // InternalTestgeneratorDSL.g:3847:7: (lv_mocks_17_0= ruleMockReference )
+                            	    // InternalTestgeneratorDSL.g:2901:6: ( (lv_mocks_17_0= ruleMockReference ) )
+                            	    // InternalTestgeneratorDSL.g:2902:7: (lv_mocks_17_0= ruleMockReference )
                             	    {
-                            	    // InternalTestgeneratorDSL.g:3847:7: (lv_mocks_17_0= ruleMockReference )
-                            	    // InternalTestgeneratorDSL.g:3848:8: lv_mocks_17_0= ruleMockReference
+                            	    // InternalTestgeneratorDSL.g:2902:7: (lv_mocks_17_0= ruleMockReference )
+                            	    // InternalTestgeneratorDSL.g:2903:8: lv_mocks_17_0= ruleMockReference
                             	    {
 
                             	    								newCompositeNode(grammarAccess.getTestAccess().getMocksMockReferenceParserRuleCall_7_4_1_1_0());
@@ -8858,7 +6693,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                             	    break;
 
                             	default :
-                            	    break loop89;
+                            	    break loop48;
                                 }
                             } while (true);
 
@@ -8905,7 +6740,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariableDeclarations"
-    // InternalTestgeneratorDSL.g:3880:1: entryRuleVariableDeclarations returns [EObject current=null] : iv_ruleVariableDeclarations= ruleVariableDeclarations EOF ;
+    // InternalTestgeneratorDSL.g:2935:1: entryRuleVariableDeclarations returns [EObject current=null] : iv_ruleVariableDeclarations= ruleVariableDeclarations EOF ;
     public final EObject entryRuleVariableDeclarations() throws RecognitionException {
         EObject current = null;
 
@@ -8913,8 +6748,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3880:61: (iv_ruleVariableDeclarations= ruleVariableDeclarations EOF )
-            // InternalTestgeneratorDSL.g:3881:2: iv_ruleVariableDeclarations= ruleVariableDeclarations EOF
+            // InternalTestgeneratorDSL.g:2935:61: (iv_ruleVariableDeclarations= ruleVariableDeclarations EOF )
+            // InternalTestgeneratorDSL.g:2936:2: iv_ruleVariableDeclarations= ruleVariableDeclarations EOF
             {
              newCompositeNode(grammarAccess.getVariableDeclarationsRule()); 
             pushFollow(FOLLOW_1);
@@ -8941,7 +6776,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariableDeclarations"
-    // InternalTestgeneratorDSL.g:3887:1: ruleVariableDeclarations returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED ) ;
+    // InternalTestgeneratorDSL.g:2942:1: ruleVariableDeclarations returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED ) ;
     public final EObject ruleVariableDeclarations() throws RecognitionException {
         EObject current = null;
 
@@ -8963,29 +6798,29 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:3893:2: ( (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:3894:2: (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2948:2: ( (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:2949:2: (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:3894:2: (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:3895:3: otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:2949:2: (otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:2950:3: otherlv_0= 'with' otherlv_1= 'variables' otherlv_2= 'for' ( (lv_taskReference_3_0= ruleFlowElementReference ) ) this_ASSOCIATION_4= RULE_ASSOCIATION this_LIST_OPEN_5= RULE_LIST_OPEN ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_9= RULE_LIST_CLOSED
             {
-            otherlv_0=(Token)match(input,17,FOLLOW_60); 
+            otherlv_0=(Token)match(input,17,FOLLOW_59); 
 
             			newLeafNode(otherlv_0, grammarAccess.getVariableDeclarationsAccess().getWithKeyword_0());
             		
-            otherlv_1=(Token)match(input,65,FOLLOW_52); 
+            otherlv_1=(Token)match(input,63,FOLLOW_52); 
 
             			newLeafNode(otherlv_1, grammarAccess.getVariableDeclarationsAccess().getVariablesKeyword_1());
             		
-            otherlv_2=(Token)match(input,58,FOLLOW_4); 
+            otherlv_2=(Token)match(input,56,FOLLOW_4); 
 
             			newLeafNode(otherlv_2, grammarAccess.getVariableDeclarationsAccess().getForKeyword_2());
             		
-            // InternalTestgeneratorDSL.g:3907:3: ( (lv_taskReference_3_0= ruleFlowElementReference ) )
-            // InternalTestgeneratorDSL.g:3908:4: (lv_taskReference_3_0= ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:2962:3: ( (lv_taskReference_3_0= ruleFlowElementReference ) )
+            // InternalTestgeneratorDSL.g:2963:4: (lv_taskReference_3_0= ruleFlowElementReference )
             {
-            // InternalTestgeneratorDSL.g:3908:4: (lv_taskReference_3_0= ruleFlowElementReference )
-            // InternalTestgeneratorDSL.g:3909:5: lv_taskReference_3_0= ruleFlowElementReference
+            // InternalTestgeneratorDSL.g:2963:4: (lv_taskReference_3_0= ruleFlowElementReference )
+            // InternalTestgeneratorDSL.g:2964:5: lv_taskReference_3_0= ruleFlowElementReference
             {
 
             					newCompositeNode(grammarAccess.getVariableDeclarationsAccess().getTaskReferenceFlowElementReferenceParserRuleCall_3_0());
@@ -9016,26 +6851,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_ASSOCIATION_4, grammarAccess.getVariableDeclarationsAccess().getASSOCIATIONTerminalRuleCall_4());
             		
-            this_LIST_OPEN_5=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+            this_LIST_OPEN_5=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
             			newLeafNode(this_LIST_OPEN_5, grammarAccess.getVariableDeclarationsAccess().getLIST_OPENTerminalRuleCall_5());
             		
-            // InternalTestgeneratorDSL.g:3934:3: ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )?
-            int alt93=2;
-            int LA93_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:2989:3: ( ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )* )?
+            int alt52=2;
+            int LA52_0 = input.LA(1);
 
-            if ( (LA93_0==RULE_ID) ) {
-                alt93=1;
+            if ( (LA52_0==RULE_ID) ) {
+                alt52=1;
             }
-            switch (alt93) {
+            switch (alt52) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:3935:4: ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )*
+                    // InternalTestgeneratorDSL.g:2990:4: ( (lv_variables_6_0= ruleVariableDeclaration ) ) (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:3935:4: ( (lv_variables_6_0= ruleVariableDeclaration ) )
-                    // InternalTestgeneratorDSL.g:3936:5: (lv_variables_6_0= ruleVariableDeclaration )
+                    // InternalTestgeneratorDSL.g:2990:4: ( (lv_variables_6_0= ruleVariableDeclaration ) )
+                    // InternalTestgeneratorDSL.g:2991:5: (lv_variables_6_0= ruleVariableDeclaration )
                     {
-                    // InternalTestgeneratorDSL.g:3936:5: (lv_variables_6_0= ruleVariableDeclaration )
-                    // InternalTestgeneratorDSL.g:3937:6: lv_variables_6_0= ruleVariableDeclaration
+                    // InternalTestgeneratorDSL.g:2991:5: (lv_variables_6_0= ruleVariableDeclaration )
+                    // InternalTestgeneratorDSL.g:2992:6: lv_variables_6_0= ruleVariableDeclaration
                     {
 
                     						newCompositeNode(grammarAccess.getVariableDeclarationsAccess().getVariablesVariableDeclarationParserRuleCall_6_0_0());
@@ -9062,30 +6897,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:3954:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )*
-                    loop92:
+                    // InternalTestgeneratorDSL.g:3009:4: (this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) ) )*
+                    loop51:
                     do {
-                        int alt92=2;
-                        int LA92_0 = input.LA(1);
+                        int alt51=2;
+                        int LA51_0 = input.LA(1);
 
-                        if ( (LA92_0==RULE_SEPARATOR) ) {
-                            alt92=1;
+                        if ( (LA51_0==RULE_SEPARATOR) ) {
+                            alt51=1;
                         }
 
 
-                        switch (alt92) {
+                        switch (alt51) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:3955:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) )
+                    	    // InternalTestgeneratorDSL.g:3010:5: this_SEPARATOR_7= RULE_SEPARATOR ( (lv_variables_8_0= ruleVariableDeclaration ) )
                     	    {
                     	    this_SEPARATOR_7=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                     	    					newLeafNode(this_SEPARATOR_7, grammarAccess.getVariableDeclarationsAccess().getSEPARATORTerminalRuleCall_6_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:3959:5: ( (lv_variables_8_0= ruleVariableDeclaration ) )
-                    	    // InternalTestgeneratorDSL.g:3960:6: (lv_variables_8_0= ruleVariableDeclaration )
+                    	    // InternalTestgeneratorDSL.g:3014:5: ( (lv_variables_8_0= ruleVariableDeclaration ) )
+                    	    // InternalTestgeneratorDSL.g:3015:6: (lv_variables_8_0= ruleVariableDeclaration )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:3960:6: (lv_variables_8_0= ruleVariableDeclaration )
-                    	    // InternalTestgeneratorDSL.g:3961:7: lv_variables_8_0= ruleVariableDeclaration
+                    	    // InternalTestgeneratorDSL.g:3015:6: (lv_variables_8_0= ruleVariableDeclaration )
+                    	    // InternalTestgeneratorDSL.g:3016:7: lv_variables_8_0= ruleVariableDeclaration
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getVariableDeclarationsAccess().getVariablesVariableDeclarationParserRuleCall_6_1_1_0());
@@ -9117,7 +6952,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop92;
+                    	    break loop51;
                         }
                     } while (true);
 
@@ -9154,7 +6989,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleEndChecks"
-    // InternalTestgeneratorDSL.g:3988:1: entryRuleEndChecks returns [EObject current=null] : iv_ruleEndChecks= ruleEndChecks EOF ;
+    // InternalTestgeneratorDSL.g:3043:1: entryRuleEndChecks returns [EObject current=null] : iv_ruleEndChecks= ruleEndChecks EOF ;
     public final EObject entryRuleEndChecks() throws RecognitionException {
         EObject current = null;
 
@@ -9162,8 +6997,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:3988:50: (iv_ruleEndChecks= ruleEndChecks EOF )
-            // InternalTestgeneratorDSL.g:3989:2: iv_ruleEndChecks= ruleEndChecks EOF
+            // InternalTestgeneratorDSL.g:3043:50: (iv_ruleEndChecks= ruleEndChecks EOF )
+            // InternalTestgeneratorDSL.g:3044:2: iv_ruleEndChecks= ruleEndChecks EOF
             {
              newCompositeNode(grammarAccess.getEndChecksRule()); 
             pushFollow(FOLLOW_1);
@@ -9190,7 +7025,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleEndChecks"
-    // InternalTestgeneratorDSL.g:3995:1: ruleEndChecks returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED ) ;
+    // InternalTestgeneratorDSL.g:3050:1: ruleEndChecks returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED ) ;
     public final EObject ruleEndChecks() throws RecognitionException {
         EObject current = null;
 
@@ -9209,17 +7044,17 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4001:2: ( (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:4002:2: (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3056:2: ( (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:3057:2: (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:4002:2: (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:4003:3: otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:3057:2: (otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:3058:3: otherlv_0= 'with' otherlv_1= 'check' this_ASSOCIATION_2= RULE_ASSOCIATION this_LIST_OPEN_3= RULE_LIST_OPEN ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )? this_LIST_CLOSED_7= RULE_LIST_CLOSED
             {
-            otherlv_0=(Token)match(input,17,FOLLOW_61); 
+            otherlv_0=(Token)match(input,17,FOLLOW_60); 
 
             			newLeafNode(otherlv_0, grammarAccess.getEndChecksAccess().getWithKeyword_0());
             		
-            otherlv_1=(Token)match(input,66,FOLLOW_12); 
+            otherlv_1=(Token)match(input,64,FOLLOW_12); 
 
             			newLeafNode(otherlv_1, grammarAccess.getEndChecksAccess().getCheckKeyword_1());
             		
@@ -9227,26 +7062,26 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getEndChecksAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            this_LIST_OPEN_3=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+            this_LIST_OPEN_3=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
             			newLeafNode(this_LIST_OPEN_3, grammarAccess.getEndChecksAccess().getLIST_OPENTerminalRuleCall_3());
             		
-            // InternalTestgeneratorDSL.g:4019:3: ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )?
-            int alt95=2;
-            int LA95_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3074:3: ( ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )* )?
+            int alt54=2;
+            int LA54_0 = input.LA(1);
 
-            if ( (LA95_0==RULE_ID) ) {
-                alt95=1;
+            if ( (LA54_0==RULE_ID) ) {
+                alt54=1;
             }
-            switch (alt95) {
+            switch (alt54) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4020:4: ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )*
+                    // InternalTestgeneratorDSL.g:3075:4: ( (lv_endChecks_4_0= ruleEndCheck ) ) (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:4020:4: ( (lv_endChecks_4_0= ruleEndCheck ) )
-                    // InternalTestgeneratorDSL.g:4021:5: (lv_endChecks_4_0= ruleEndCheck )
+                    // InternalTestgeneratorDSL.g:3075:4: ( (lv_endChecks_4_0= ruleEndCheck ) )
+                    // InternalTestgeneratorDSL.g:3076:5: (lv_endChecks_4_0= ruleEndCheck )
                     {
-                    // InternalTestgeneratorDSL.g:4021:5: (lv_endChecks_4_0= ruleEndCheck )
-                    // InternalTestgeneratorDSL.g:4022:6: lv_endChecks_4_0= ruleEndCheck
+                    // InternalTestgeneratorDSL.g:3076:5: (lv_endChecks_4_0= ruleEndCheck )
+                    // InternalTestgeneratorDSL.g:3077:6: lv_endChecks_4_0= ruleEndCheck
                     {
 
                     						newCompositeNode(grammarAccess.getEndChecksAccess().getEndChecksEndCheckParserRuleCall_4_0_0());
@@ -9273,30 +7108,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:4039:4: (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )*
-                    loop94:
+                    // InternalTestgeneratorDSL.g:3094:4: (this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) ) )*
+                    loop53:
                     do {
-                        int alt94=2;
-                        int LA94_0 = input.LA(1);
+                        int alt53=2;
+                        int LA53_0 = input.LA(1);
 
-                        if ( (LA94_0==RULE_SEPARATOR) ) {
-                            alt94=1;
+                        if ( (LA53_0==RULE_SEPARATOR) ) {
+                            alt53=1;
                         }
 
 
-                        switch (alt94) {
+                        switch (alt53) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:4040:5: this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) )
+                    	    // InternalTestgeneratorDSL.g:3095:5: this_SEPARATOR_5= RULE_SEPARATOR ( (lv_endChecks_6_0= ruleEndCheck ) )
                     	    {
                     	    this_SEPARATOR_5=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                     	    					newLeafNode(this_SEPARATOR_5, grammarAccess.getEndChecksAccess().getSEPARATORTerminalRuleCall_4_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:4044:5: ( (lv_endChecks_6_0= ruleEndCheck ) )
-                    	    // InternalTestgeneratorDSL.g:4045:6: (lv_endChecks_6_0= ruleEndCheck )
+                    	    // InternalTestgeneratorDSL.g:3099:5: ( (lv_endChecks_6_0= ruleEndCheck ) )
+                    	    // InternalTestgeneratorDSL.g:3100:6: (lv_endChecks_6_0= ruleEndCheck )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:4045:6: (lv_endChecks_6_0= ruleEndCheck )
-                    	    // InternalTestgeneratorDSL.g:4046:7: lv_endChecks_6_0= ruleEndCheck
+                    	    // InternalTestgeneratorDSL.g:3100:6: (lv_endChecks_6_0= ruleEndCheck )
+                    	    // InternalTestgeneratorDSL.g:3101:7: lv_endChecks_6_0= ruleEndCheck
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getEndChecksAccess().getEndChecksEndCheckParserRuleCall_4_1_1_0());
@@ -9328,7 +7163,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop94;
+                    	    break loop53;
                         }
                     } while (true);
 
@@ -9365,7 +7200,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4073:1: entryRuleVariableDeclaration returns [EObject current=null] : iv_ruleVariableDeclaration= ruleVariableDeclaration EOF ;
+    // InternalTestgeneratorDSL.g:3128:1: entryRuleVariableDeclaration returns [EObject current=null] : iv_ruleVariableDeclaration= ruleVariableDeclaration EOF ;
     public final EObject entryRuleVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9373,8 +7208,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4073:60: (iv_ruleVariableDeclaration= ruleVariableDeclaration EOF )
-            // InternalTestgeneratorDSL.g:4074:2: iv_ruleVariableDeclaration= ruleVariableDeclaration EOF
+            // InternalTestgeneratorDSL.g:3128:60: (iv_ruleVariableDeclaration= ruleVariableDeclaration EOF )
+            // InternalTestgeneratorDSL.g:3129:2: iv_ruleVariableDeclaration= ruleVariableDeclaration EOF
             {
              newCompositeNode(grammarAccess.getVariableDeclarationRule()); 
             pushFollow(FOLLOW_1);
@@ -9401,7 +7236,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4080:1: ruleVariableDeclaration returns [EObject current=null] : (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration ) ;
+    // InternalTestgeneratorDSL.g:3135:1: ruleVariableDeclaration returns [EObject current=null] : (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration ) ;
     public final EObject ruleVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9416,37 +7251,37 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4086:2: ( (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration ) )
-            // InternalTestgeneratorDSL.g:4087:2: (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration )
+            // InternalTestgeneratorDSL.g:3141:2: ( (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration ) )
+            // InternalTestgeneratorDSL.g:3142:2: (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration )
             {
-            // InternalTestgeneratorDSL.g:4087:2: (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration )
-            int alt96=3;
-            int LA96_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3142:2: (this_StringVariableDeclaration_0= ruleStringVariableDeclaration | this_IntVariableDeclaration_1= ruleIntVariableDeclaration | this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration )
+            int alt55=3;
+            int LA55_0 = input.LA(1);
 
-            if ( (LA96_0==RULE_ID) ) {
-                int LA96_1 = input.LA(2);
+            if ( (LA55_0==RULE_ID) ) {
+                int LA55_1 = input.LA(2);
 
-                if ( (LA96_1==67) ) {
+                if ( (LA55_1==65) ) {
                     switch ( input.LA(3) ) {
-                    case RULE_INT:
+                    case 76:
+                    case 77:
                         {
-                        alt96=2;
+                        alt55=3;
                         }
                         break;
-                    case 78:
-                    case 79:
+                    case RULE_STRING:
                         {
-                        alt96=3;
+                        alt55=1;
                         }
                         break;
-                    case RULE_STRING:
+                    case RULE_INT:
                         {
-                        alt96=1;
+                        alt55=2;
                         }
                         break;
                     default:
                         NoViableAltException nvae =
-                            new NoViableAltException("", 96, 2, input);
+                            new NoViableAltException("", 55, 2, input);
 
                         throw nvae;
                     }
@@ -9454,20 +7289,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                 }
                 else {
                     NoViableAltException nvae =
-                        new NoViableAltException("", 96, 1, input);
+                        new NoViableAltException("", 55, 1, input);
 
                     throw nvae;
                 }
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 96, 0, input);
+                    new NoViableAltException("", 55, 0, input);
 
                 throw nvae;
             }
-            switch (alt96) {
+            switch (alt55) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4088:3: this_StringVariableDeclaration_0= ruleStringVariableDeclaration
+                    // InternalTestgeneratorDSL.g:3143:3: this_StringVariableDeclaration_0= ruleStringVariableDeclaration
                     {
 
                     			newCompositeNode(grammarAccess.getVariableDeclarationAccess().getStringVariableDeclarationParserRuleCall_0());
@@ -9485,7 +7320,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:4097:3: this_IntVariableDeclaration_1= ruleIntVariableDeclaration
+                    // InternalTestgeneratorDSL.g:3152:3: this_IntVariableDeclaration_1= ruleIntVariableDeclaration
                     {
 
                     			newCompositeNode(grammarAccess.getVariableDeclarationAccess().getIntVariableDeclarationParserRuleCall_1());
@@ -9503,7 +7338,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:4106:3: this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration
+                    // InternalTestgeneratorDSL.g:3161:3: this_BooleanVariableDeclaration_2= ruleBooleanVariableDeclaration
                     {
 
                     			newCompositeNode(grammarAccess.getVariableDeclarationAccess().getBooleanVariableDeclarationParserRuleCall_2());
@@ -9543,7 +7378,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleStringVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4118:1: entryRuleStringVariableDeclaration returns [EObject current=null] : iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF ;
+    // InternalTestgeneratorDSL.g:3173:1: entryRuleStringVariableDeclaration returns [EObject current=null] : iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF ;
     public final EObject entryRuleStringVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9551,8 +7386,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4118:66: (iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF )
-            // InternalTestgeneratorDSL.g:4119:2: iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF
+            // InternalTestgeneratorDSL.g:3173:66: (iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF )
+            // InternalTestgeneratorDSL.g:3174:2: iv_ruleStringVariableDeclaration= ruleStringVariableDeclaration EOF
             {
              newCompositeNode(grammarAccess.getStringVariableDeclarationRule()); 
             pushFollow(FOLLOW_1);
@@ -9579,7 +7414,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4125:1: ruleStringVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) ) ;
+    // InternalTestgeneratorDSL.g:3180:1: ruleStringVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) ) ;
     public final EObject ruleStringVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9591,24 +7426,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4131:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) ) )
-            // InternalTestgeneratorDSL.g:4132:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3186:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) ) )
+            // InternalTestgeneratorDSL.g:3187:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) )
             {
-            // InternalTestgeneratorDSL.g:4132:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) )
-            // InternalTestgeneratorDSL.g:4133:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3187:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3188:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_STRING ) )
             {
-            // InternalTestgeneratorDSL.g:4133:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4134:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3188:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3189:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4134:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4135:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3189:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3190:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getStringVariableDeclarationRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_61); 
 
             					newLeafNode(otherlv_0, grammarAccess.getStringVariableDeclarationAccess().getKeyStringVariableCrossReference_0_0());
             				
@@ -9618,15 +7453,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,67,FOLLOW_7); 
+            otherlv_1=(Token)match(input,65,FOLLOW_7); 
 
             			newLeafNode(otherlv_1, grammarAccess.getStringVariableDeclarationAccess().getEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4150:3: ( (lv_value_2_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:4151:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3205:3: ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3206:4: (lv_value_2_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:4151:4: (lv_value_2_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:4152:5: lv_value_2_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:3206:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3207:5: lv_value_2_0= RULE_STRING
             {
             lv_value_2_0=(Token)match(input,RULE_STRING,FOLLOW_2); 
 
@@ -9671,7 +7506,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleIntVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4172:1: entryRuleIntVariableDeclaration returns [EObject current=null] : iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF ;
+    // InternalTestgeneratorDSL.g:3227:1: entryRuleIntVariableDeclaration returns [EObject current=null] : iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF ;
     public final EObject entryRuleIntVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9679,8 +7514,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4172:63: (iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF )
-            // InternalTestgeneratorDSL.g:4173:2: iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF
+            // InternalTestgeneratorDSL.g:3227:63: (iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF )
+            // InternalTestgeneratorDSL.g:3228:2: iv_ruleIntVariableDeclaration= ruleIntVariableDeclaration EOF
             {
              newCompositeNode(grammarAccess.getIntVariableDeclarationRule()); 
             pushFollow(FOLLOW_1);
@@ -9707,7 +7542,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4179:1: ruleIntVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) ) ;
+    // InternalTestgeneratorDSL.g:3234:1: ruleIntVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) ) ;
     public final EObject ruleIntVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9719,24 +7554,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4185:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) ) )
-            // InternalTestgeneratorDSL.g:4186:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3240:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) ) )
+            // InternalTestgeneratorDSL.g:3241:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) )
             {
-            // InternalTestgeneratorDSL.g:4186:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) )
-            // InternalTestgeneratorDSL.g:4187:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3241:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3242:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= RULE_INT ) )
             {
-            // InternalTestgeneratorDSL.g:4187:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4188:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3242:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3243:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4188:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4189:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3243:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3244:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getIntVariableDeclarationRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_61); 
 
             					newLeafNode(otherlv_0, grammarAccess.getIntVariableDeclarationAccess().getKeyIntVariableCrossReference_0_0());
             				
@@ -9746,15 +7581,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,67,FOLLOW_42); 
+            otherlv_1=(Token)match(input,65,FOLLOW_42); 
 
             			newLeafNode(otherlv_1, grammarAccess.getIntVariableDeclarationAccess().getEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4204:3: ( (lv_value_2_0= RULE_INT ) )
-            // InternalTestgeneratorDSL.g:4205:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3259:3: ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3260:4: (lv_value_2_0= RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:4205:4: (lv_value_2_0= RULE_INT )
-            // InternalTestgeneratorDSL.g:4206:5: lv_value_2_0= RULE_INT
+            // InternalTestgeneratorDSL.g:3260:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3261:5: lv_value_2_0= RULE_INT
             {
             lv_value_2_0=(Token)match(input,RULE_INT,FOLLOW_2); 
 
@@ -9799,7 +7634,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleBooleanVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4226:1: entryRuleBooleanVariableDeclaration returns [EObject current=null] : iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF ;
+    // InternalTestgeneratorDSL.g:3281:1: entryRuleBooleanVariableDeclaration returns [EObject current=null] : iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF ;
     public final EObject entryRuleBooleanVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9807,8 +7642,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4226:67: (iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF )
-            // InternalTestgeneratorDSL.g:4227:2: iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF
+            // InternalTestgeneratorDSL.g:3281:67: (iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF )
+            // InternalTestgeneratorDSL.g:3282:2: iv_ruleBooleanVariableDeclaration= ruleBooleanVariableDeclaration EOF
             {
              newCompositeNode(grammarAccess.getBooleanVariableDeclarationRule()); 
             pushFollow(FOLLOW_1);
@@ -9835,7 +7670,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanVariableDeclaration"
-    // InternalTestgeneratorDSL.g:4233:1: ruleBooleanVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) ) ;
+    // InternalTestgeneratorDSL.g:3288:1: ruleBooleanVariableDeclaration returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) ) ;
     public final EObject ruleBooleanVariableDeclaration() throws RecognitionException {
         EObject current = null;
 
@@ -9848,24 +7683,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4239:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) ) )
-            // InternalTestgeneratorDSL.g:4240:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3294:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) ) )
+            // InternalTestgeneratorDSL.g:3295:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) )
             {
-            // InternalTestgeneratorDSL.g:4240:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) )
-            // InternalTestgeneratorDSL.g:4241:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3295:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3296:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '=' ( (lv_value_2_0= ruleBoolean ) )
             {
-            // InternalTestgeneratorDSL.g:4241:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4242:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3296:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3297:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4242:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4243:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3297:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3298:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getBooleanVariableDeclarationRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_61); 
 
             					newLeafNode(otherlv_0, grammarAccess.getBooleanVariableDeclarationAccess().getKeyBooleanVariableCrossReference_0_0());
             				
@@ -9875,15 +7710,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,67,FOLLOW_44); 
+            otherlv_1=(Token)match(input,65,FOLLOW_44); 
 
             			newLeafNode(otherlv_1, grammarAccess.getBooleanVariableDeclarationAccess().getEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4258:3: ( (lv_value_2_0= ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:4259:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3313:3: ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3314:4: (lv_value_2_0= ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:4259:4: (lv_value_2_0= ruleBoolean )
-            // InternalTestgeneratorDSL.g:4260:5: lv_value_2_0= ruleBoolean
+            // InternalTestgeneratorDSL.g:3314:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3315:5: lv_value_2_0= ruleBoolean
             {
 
             					newCompositeNode(grammarAccess.getBooleanVariableDeclarationAccess().getValueBooleanEnumRuleCall_2_0());
@@ -9933,7 +7768,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleEndCheck"
-    // InternalTestgeneratorDSL.g:4281:1: entryRuleEndCheck returns [EObject current=null] : iv_ruleEndCheck= ruleEndCheck EOF ;
+    // InternalTestgeneratorDSL.g:3336:1: entryRuleEndCheck returns [EObject current=null] : iv_ruleEndCheck= ruleEndCheck EOF ;
     public final EObject entryRuleEndCheck() throws RecognitionException {
         EObject current = null;
 
@@ -9941,8 +7776,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4281:49: (iv_ruleEndCheck= ruleEndCheck EOF )
-            // InternalTestgeneratorDSL.g:4282:2: iv_ruleEndCheck= ruleEndCheck EOF
+            // InternalTestgeneratorDSL.g:3336:49: (iv_ruleEndCheck= ruleEndCheck EOF )
+            // InternalTestgeneratorDSL.g:3337:2: iv_ruleEndCheck= ruleEndCheck EOF
             {
              newCompositeNode(grammarAccess.getEndCheckRule()); 
             pushFollow(FOLLOW_1);
@@ -9969,7 +7804,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleEndCheck"
-    // InternalTestgeneratorDSL.g:4288:1: ruleEndCheck returns [EObject current=null] : (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals ) ;
+    // InternalTestgeneratorDSL.g:3343:1: ruleEndCheck returns [EObject current=null] : (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals ) ;
     public final EObject ruleEndCheck() throws RecognitionException {
         EObject current = null;
 
@@ -9982,38 +7817,38 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4294:2: ( (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals ) )
-            // InternalTestgeneratorDSL.g:4295:2: (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals )
+            // InternalTestgeneratorDSL.g:3349:2: ( (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals ) )
+            // InternalTestgeneratorDSL.g:3350:2: (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals )
             {
-            // InternalTestgeneratorDSL.g:4295:2: (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals )
-            int alt97=2;
-            int LA97_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3350:2: (this_VariableEquals_0= ruleVariableEquals | this_VariableNotEquals_1= ruleVariableNotEquals )
+            int alt56=2;
+            int LA56_0 = input.LA(1);
 
-            if ( (LA97_0==RULE_ID) ) {
-                int LA97_1 = input.LA(2);
+            if ( (LA56_0==RULE_ID) ) {
+                int LA56_1 = input.LA(2);
 
-                if ( (LA97_1==68) ) {
-                    alt97=1;
+                if ( (LA56_1==66) ) {
+                    alt56=1;
                 }
-                else if ( (LA97_1==69) ) {
-                    alt97=2;
+                else if ( (LA56_1==67) ) {
+                    alt56=2;
                 }
                 else {
                     NoViableAltException nvae =
-                        new NoViableAltException("", 97, 1, input);
+                        new NoViableAltException("", 56, 1, input);
 
                     throw nvae;
                 }
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 97, 0, input);
+                    new NoViableAltException("", 56, 0, input);
 
                 throw nvae;
             }
-            switch (alt97) {
+            switch (alt56) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4296:3: this_VariableEquals_0= ruleVariableEquals
+                    // InternalTestgeneratorDSL.g:3351:3: this_VariableEquals_0= ruleVariableEquals
                     {
 
                     			newCompositeNode(grammarAccess.getEndCheckAccess().getVariableEqualsParserRuleCall_0());
@@ -10031,7 +7866,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:4305:3: this_VariableNotEquals_1= ruleVariableNotEquals
+                    // InternalTestgeneratorDSL.g:3360:3: this_VariableNotEquals_1= ruleVariableNotEquals
                     {
 
                     			newCompositeNode(grammarAccess.getEndCheckAccess().getVariableNotEqualsParserRuleCall_1());
@@ -10071,7 +7906,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariableEquals"
-    // InternalTestgeneratorDSL.g:4317:1: entryRuleVariableEquals returns [EObject current=null] : iv_ruleVariableEquals= ruleVariableEquals EOF ;
+    // InternalTestgeneratorDSL.g:3372:1: entryRuleVariableEquals returns [EObject current=null] : iv_ruleVariableEquals= ruleVariableEquals EOF ;
     public final EObject entryRuleVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10079,8 +7914,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4317:55: (iv_ruleVariableEquals= ruleVariableEquals EOF )
-            // InternalTestgeneratorDSL.g:4318:2: iv_ruleVariableEquals= ruleVariableEquals EOF
+            // InternalTestgeneratorDSL.g:3372:55: (iv_ruleVariableEquals= ruleVariableEquals EOF )
+            // InternalTestgeneratorDSL.g:3373:2: iv_ruleVariableEquals= ruleVariableEquals EOF
             {
              newCompositeNode(grammarAccess.getVariableEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10107,7 +7942,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariableEquals"
-    // InternalTestgeneratorDSL.g:4324:1: ruleVariableEquals returns [EObject current=null] : (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals ) ;
+    // InternalTestgeneratorDSL.g:3379:1: ruleVariableEquals returns [EObject current=null] : (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals ) ;
     public final EObject ruleVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10122,37 +7957,37 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4330:2: ( (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals ) )
-            // InternalTestgeneratorDSL.g:4331:2: (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals )
+            // InternalTestgeneratorDSL.g:3385:2: ( (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals ) )
+            // InternalTestgeneratorDSL.g:3386:2: (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals )
             {
-            // InternalTestgeneratorDSL.g:4331:2: (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals )
-            int alt98=3;
-            int LA98_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3386:2: (this_StringVariableEquals_0= ruleStringVariableEquals | this_IntVariableEquals_1= ruleIntVariableEquals | this_BooleanVariableEquals_2= ruleBooleanVariableEquals )
+            int alt57=3;
+            int LA57_0 = input.LA(1);
 
-            if ( (LA98_0==RULE_ID) ) {
-                int LA98_1 = input.LA(2);
+            if ( (LA57_0==RULE_ID) ) {
+                int LA57_1 = input.LA(2);
 
-                if ( (LA98_1==68) ) {
+                if ( (LA57_1==66) ) {
                     switch ( input.LA(3) ) {
-                    case 78:
-                    case 79:
+                    case RULE_INT:
                         {
-                        alt98=3;
+                        alt57=2;
                         }
                         break;
-                    case RULE_STRING:
+                    case 76:
+                    case 77:
                         {
-                        alt98=1;
+                        alt57=3;
                         }
                         break;
-                    case RULE_INT:
+                    case RULE_STRING:
                         {
-                        alt98=2;
+                        alt57=1;
                         }
                         break;
                     default:
                         NoViableAltException nvae =
-                            new NoViableAltException("", 98, 2, input);
+                            new NoViableAltException("", 57, 2, input);
 
                         throw nvae;
                     }
@@ -10160,20 +7995,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                 }
                 else {
                     NoViableAltException nvae =
-                        new NoViableAltException("", 98, 1, input);
+                        new NoViableAltException("", 57, 1, input);
 
                     throw nvae;
                 }
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 98, 0, input);
+                    new NoViableAltException("", 57, 0, input);
 
                 throw nvae;
             }
-            switch (alt98) {
+            switch (alt57) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4332:3: this_StringVariableEquals_0= ruleStringVariableEquals
+                    // InternalTestgeneratorDSL.g:3387:3: this_StringVariableEquals_0= ruleStringVariableEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableEqualsAccess().getStringVariableEqualsParserRuleCall_0());
@@ -10191,7 +8026,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:4341:3: this_IntVariableEquals_1= ruleIntVariableEquals
+                    // InternalTestgeneratorDSL.g:3396:3: this_IntVariableEquals_1= ruleIntVariableEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableEqualsAccess().getIntVariableEqualsParserRuleCall_1());
@@ -10209,7 +8044,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:4350:3: this_BooleanVariableEquals_2= ruleBooleanVariableEquals
+                    // InternalTestgeneratorDSL.g:3405:3: this_BooleanVariableEquals_2= ruleBooleanVariableEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableEqualsAccess().getBooleanVariableEqualsParserRuleCall_2());
@@ -10249,7 +8084,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleStringVariableEquals"
-    // InternalTestgeneratorDSL.g:4362:1: entryRuleStringVariableEquals returns [EObject current=null] : iv_ruleStringVariableEquals= ruleStringVariableEquals EOF ;
+    // InternalTestgeneratorDSL.g:3417:1: entryRuleStringVariableEquals returns [EObject current=null] : iv_ruleStringVariableEquals= ruleStringVariableEquals EOF ;
     public final EObject entryRuleStringVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10257,8 +8092,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4362:61: (iv_ruleStringVariableEquals= ruleStringVariableEquals EOF )
-            // InternalTestgeneratorDSL.g:4363:2: iv_ruleStringVariableEquals= ruleStringVariableEquals EOF
+            // InternalTestgeneratorDSL.g:3417:61: (iv_ruleStringVariableEquals= ruleStringVariableEquals EOF )
+            // InternalTestgeneratorDSL.g:3418:2: iv_ruleStringVariableEquals= ruleStringVariableEquals EOF
             {
              newCompositeNode(grammarAccess.getStringVariableEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10285,7 +8120,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringVariableEquals"
-    // InternalTestgeneratorDSL.g:4369:1: ruleStringVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) ) ;
+    // InternalTestgeneratorDSL.g:3424:1: ruleStringVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) ) ;
     public final EObject ruleStringVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10297,24 +8132,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4375:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) ) )
-            // InternalTestgeneratorDSL.g:4376:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3430:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) ) )
+            // InternalTestgeneratorDSL.g:3431:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) )
             {
-            // InternalTestgeneratorDSL.g:4376:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) )
-            // InternalTestgeneratorDSL.g:4377:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3431:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3432:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_STRING ) )
             {
-            // InternalTestgeneratorDSL.g:4377:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4378:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3432:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3433:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4378:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4379:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3433:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3434:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getStringVariableEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
 
             					newLeafNode(otherlv_0, grammarAccess.getStringVariableEqualsAccess().getKeyStringVariableCrossReference_0_0());
             				
@@ -10324,15 +8159,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,68,FOLLOW_7); 
+            otherlv_1=(Token)match(input,66,FOLLOW_7); 
 
             			newLeafNode(otherlv_1, grammarAccess.getStringVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4394:3: ( (lv_value_2_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:4395:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3449:3: ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3450:4: (lv_value_2_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:4395:4: (lv_value_2_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:4396:5: lv_value_2_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:3450:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3451:5: lv_value_2_0= RULE_STRING
             {
             lv_value_2_0=(Token)match(input,RULE_STRING,FOLLOW_2); 
 
@@ -10377,7 +8212,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleIntVariableEquals"
-    // InternalTestgeneratorDSL.g:4416:1: entryRuleIntVariableEquals returns [EObject current=null] : iv_ruleIntVariableEquals= ruleIntVariableEquals EOF ;
+    // InternalTestgeneratorDSL.g:3471:1: entryRuleIntVariableEquals returns [EObject current=null] : iv_ruleIntVariableEquals= ruleIntVariableEquals EOF ;
     public final EObject entryRuleIntVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10385,8 +8220,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4416:58: (iv_ruleIntVariableEquals= ruleIntVariableEquals EOF )
-            // InternalTestgeneratorDSL.g:4417:2: iv_ruleIntVariableEquals= ruleIntVariableEquals EOF
+            // InternalTestgeneratorDSL.g:3471:58: (iv_ruleIntVariableEquals= ruleIntVariableEquals EOF )
+            // InternalTestgeneratorDSL.g:3472:2: iv_ruleIntVariableEquals= ruleIntVariableEquals EOF
             {
              newCompositeNode(grammarAccess.getIntVariableEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10413,7 +8248,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntVariableEquals"
-    // InternalTestgeneratorDSL.g:4423:1: ruleIntVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) ) ;
+    // InternalTestgeneratorDSL.g:3478:1: ruleIntVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) ) ;
     public final EObject ruleIntVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10425,24 +8260,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4429:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) ) )
-            // InternalTestgeneratorDSL.g:4430:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3484:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) ) )
+            // InternalTestgeneratorDSL.g:3485:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) )
             {
-            // InternalTestgeneratorDSL.g:4430:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) )
-            // InternalTestgeneratorDSL.g:4431:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3485:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3486:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= RULE_INT ) )
             {
-            // InternalTestgeneratorDSL.g:4431:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4432:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3486:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3487:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4432:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4433:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3487:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3488:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getIntVariableEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
 
             					newLeafNode(otherlv_0, grammarAccess.getIntVariableEqualsAccess().getKeyIntVariableCrossReference_0_0());
             				
@@ -10452,15 +8287,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,68,FOLLOW_42); 
+            otherlv_1=(Token)match(input,66,FOLLOW_42); 
 
             			newLeafNode(otherlv_1, grammarAccess.getIntVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4448:3: ( (lv_value_2_0= RULE_INT ) )
-            // InternalTestgeneratorDSL.g:4449:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3503:3: ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3504:4: (lv_value_2_0= RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:4449:4: (lv_value_2_0= RULE_INT )
-            // InternalTestgeneratorDSL.g:4450:5: lv_value_2_0= RULE_INT
+            // InternalTestgeneratorDSL.g:3504:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3505:5: lv_value_2_0= RULE_INT
             {
             lv_value_2_0=(Token)match(input,RULE_INT,FOLLOW_2); 
 
@@ -10505,7 +8340,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleBooleanVariableEquals"
-    // InternalTestgeneratorDSL.g:4470:1: entryRuleBooleanVariableEquals returns [EObject current=null] : iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF ;
+    // InternalTestgeneratorDSL.g:3525:1: entryRuleBooleanVariableEquals returns [EObject current=null] : iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF ;
     public final EObject entryRuleBooleanVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10513,8 +8348,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4470:62: (iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF )
-            // InternalTestgeneratorDSL.g:4471:2: iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF
+            // InternalTestgeneratorDSL.g:3525:62: (iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF )
+            // InternalTestgeneratorDSL.g:3526:2: iv_ruleBooleanVariableEquals= ruleBooleanVariableEquals EOF
             {
              newCompositeNode(grammarAccess.getBooleanVariableEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10541,7 +8376,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanVariableEquals"
-    // InternalTestgeneratorDSL.g:4477:1: ruleBooleanVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) ) ;
+    // InternalTestgeneratorDSL.g:3532:1: ruleBooleanVariableEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) ) ;
     public final EObject ruleBooleanVariableEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10554,24 +8389,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4483:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) ) )
-            // InternalTestgeneratorDSL.g:4484:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3538:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) ) )
+            // InternalTestgeneratorDSL.g:3539:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) )
             {
-            // InternalTestgeneratorDSL.g:4484:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) )
-            // InternalTestgeneratorDSL.g:4485:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3539:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3540:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '==' ( (lv_value_2_0= ruleBoolean ) )
             {
-            // InternalTestgeneratorDSL.g:4485:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4486:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3540:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3541:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4486:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4487:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3541:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3542:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getBooleanVariableEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_62); 
 
             					newLeafNode(otherlv_0, grammarAccess.getBooleanVariableEqualsAccess().getKeyBooleanVariableCrossReference_0_0());
             				
@@ -10581,15 +8416,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,68,FOLLOW_44); 
+            otherlv_1=(Token)match(input,66,FOLLOW_44); 
 
             			newLeafNode(otherlv_1, grammarAccess.getBooleanVariableEqualsAccess().getEqualsSignEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4502:3: ( (lv_value_2_0= ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:4503:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3557:3: ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3558:4: (lv_value_2_0= ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:4503:4: (lv_value_2_0= ruleBoolean )
-            // InternalTestgeneratorDSL.g:4504:5: lv_value_2_0= ruleBoolean
+            // InternalTestgeneratorDSL.g:3558:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3559:5: lv_value_2_0= ruleBoolean
             {
 
             					newCompositeNode(grammarAccess.getBooleanVariableEqualsAccess().getValueBooleanEnumRuleCall_2_0());
@@ -10639,7 +8474,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4525:1: entryRuleVariableNotEquals returns [EObject current=null] : iv_ruleVariableNotEquals= ruleVariableNotEquals EOF ;
+    // InternalTestgeneratorDSL.g:3580:1: entryRuleVariableNotEquals returns [EObject current=null] : iv_ruleVariableNotEquals= ruleVariableNotEquals EOF ;
     public final EObject entryRuleVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10647,8 +8482,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4525:58: (iv_ruleVariableNotEquals= ruleVariableNotEquals EOF )
-            // InternalTestgeneratorDSL.g:4526:2: iv_ruleVariableNotEquals= ruleVariableNotEquals EOF
+            // InternalTestgeneratorDSL.g:3580:58: (iv_ruleVariableNotEquals= ruleVariableNotEquals EOF )
+            // InternalTestgeneratorDSL.g:3581:2: iv_ruleVariableNotEquals= ruleVariableNotEquals EOF
             {
              newCompositeNode(grammarAccess.getVariableNotEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10675,7 +8510,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4532:1: ruleVariableNotEquals returns [EObject current=null] : (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals ) ;
+    // InternalTestgeneratorDSL.g:3587:1: ruleVariableNotEquals returns [EObject current=null] : (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals ) ;
     public final EObject ruleVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10690,37 +8525,37 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4538:2: ( (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals ) )
-            // InternalTestgeneratorDSL.g:4539:2: (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals )
+            // InternalTestgeneratorDSL.g:3593:2: ( (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals ) )
+            // InternalTestgeneratorDSL.g:3594:2: (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals )
             {
-            // InternalTestgeneratorDSL.g:4539:2: (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals )
-            int alt99=3;
-            int LA99_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3594:2: (this_StringVariableNotEquals_0= ruleStringVariableNotEquals | this_IntVariableNotEquals_1= ruleIntVariableNotEquals | this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals )
+            int alt58=3;
+            int LA58_0 = input.LA(1);
 
-            if ( (LA99_0==RULE_ID) ) {
-                int LA99_1 = input.LA(2);
+            if ( (LA58_0==RULE_ID) ) {
+                int LA58_1 = input.LA(2);
 
-                if ( (LA99_1==69) ) {
+                if ( (LA58_1==67) ) {
                     switch ( input.LA(3) ) {
-                    case 78:
-                    case 79:
+                    case 76:
+                    case 77:
                         {
-                        alt99=3;
+                        alt58=3;
                         }
                         break;
                     case RULE_STRING:
                         {
-                        alt99=1;
+                        alt58=1;
                         }
                         break;
                     case RULE_INT:
                         {
-                        alt99=2;
+                        alt58=2;
                         }
                         break;
                     default:
                         NoViableAltException nvae =
-                            new NoViableAltException("", 99, 2, input);
+                            new NoViableAltException("", 58, 2, input);
 
                         throw nvae;
                     }
@@ -10728,20 +8563,20 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                 }
                 else {
                     NoViableAltException nvae =
-                        new NoViableAltException("", 99, 1, input);
+                        new NoViableAltException("", 58, 1, input);
 
                     throw nvae;
                 }
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 99, 0, input);
+                    new NoViableAltException("", 58, 0, input);
 
                 throw nvae;
             }
-            switch (alt99) {
+            switch (alt58) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4540:3: this_StringVariableNotEquals_0= ruleStringVariableNotEquals
+                    // InternalTestgeneratorDSL.g:3595:3: this_StringVariableNotEquals_0= ruleStringVariableNotEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableNotEqualsAccess().getStringVariableNotEqualsParserRuleCall_0());
@@ -10759,7 +8594,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:4549:3: this_IntVariableNotEquals_1= ruleIntVariableNotEquals
+                    // InternalTestgeneratorDSL.g:3604:3: this_IntVariableNotEquals_1= ruleIntVariableNotEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableNotEqualsAccess().getIntVariableNotEqualsParserRuleCall_1());
@@ -10777,7 +8612,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:4558:3: this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals
+                    // InternalTestgeneratorDSL.g:3613:3: this_BooleanVariableNotEquals_2= ruleBooleanVariableNotEquals
                     {
 
                     			newCompositeNode(grammarAccess.getVariableNotEqualsAccess().getBooleanVariableNotEqualsParserRuleCall_2());
@@ -10817,7 +8652,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleStringVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4570:1: entryRuleStringVariableNotEquals returns [EObject current=null] : iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF ;
+    // InternalTestgeneratorDSL.g:3625:1: entryRuleStringVariableNotEquals returns [EObject current=null] : iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF ;
     public final EObject entryRuleStringVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10825,8 +8660,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4570:64: (iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF )
-            // InternalTestgeneratorDSL.g:4571:2: iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF
+            // InternalTestgeneratorDSL.g:3625:64: (iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF )
+            // InternalTestgeneratorDSL.g:3626:2: iv_ruleStringVariableNotEquals= ruleStringVariableNotEquals EOF
             {
              newCompositeNode(grammarAccess.getStringVariableNotEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10853,7 +8688,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4577:1: ruleStringVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) ) ;
+    // InternalTestgeneratorDSL.g:3632:1: ruleStringVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) ) ;
     public final EObject ruleStringVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10865,24 +8700,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4583:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) ) )
-            // InternalTestgeneratorDSL.g:4584:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3638:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) ) )
+            // InternalTestgeneratorDSL.g:3639:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) )
             {
-            // InternalTestgeneratorDSL.g:4584:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) )
-            // InternalTestgeneratorDSL.g:4585:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3639:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:3640:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_STRING ) )
             {
-            // InternalTestgeneratorDSL.g:4585:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4586:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3640:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3641:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4586:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4587:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3641:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3642:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getStringVariableNotEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_64); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
 
             					newLeafNode(otherlv_0, grammarAccess.getStringVariableNotEqualsAccess().getKeyStringVariableCrossReference_0_0());
             				
@@ -10892,15 +8727,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,69,FOLLOW_7); 
+            otherlv_1=(Token)match(input,67,FOLLOW_7); 
 
             			newLeafNode(otherlv_1, grammarAccess.getStringVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4602:3: ( (lv_value_2_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:4603:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3657:3: ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:3658:4: (lv_value_2_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:4603:4: (lv_value_2_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:4604:5: lv_value_2_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:3658:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:3659:5: lv_value_2_0= RULE_STRING
             {
             lv_value_2_0=(Token)match(input,RULE_STRING,FOLLOW_2); 
 
@@ -10945,7 +8780,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleIntVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4624:1: entryRuleIntVariableNotEquals returns [EObject current=null] : iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF ;
+    // InternalTestgeneratorDSL.g:3679:1: entryRuleIntVariableNotEquals returns [EObject current=null] : iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF ;
     public final EObject entryRuleIntVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10953,8 +8788,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4624:61: (iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF )
-            // InternalTestgeneratorDSL.g:4625:2: iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF
+            // InternalTestgeneratorDSL.g:3679:61: (iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF )
+            // InternalTestgeneratorDSL.g:3680:2: iv_ruleIntVariableNotEquals= ruleIntVariableNotEquals EOF
             {
              newCompositeNode(grammarAccess.getIntVariableNotEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -10981,7 +8816,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4631:1: ruleIntVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) ) ;
+    // InternalTestgeneratorDSL.g:3686:1: ruleIntVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) ) ;
     public final EObject ruleIntVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -10993,24 +8828,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4637:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) ) )
-            // InternalTestgeneratorDSL.g:4638:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3692:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) ) )
+            // InternalTestgeneratorDSL.g:3693:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) )
             {
-            // InternalTestgeneratorDSL.g:4638:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) )
-            // InternalTestgeneratorDSL.g:4639:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3693:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:3694:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= RULE_INT ) )
             {
-            // InternalTestgeneratorDSL.g:4639:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4640:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3694:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3695:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4640:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4641:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3695:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3696:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getIntVariableNotEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_64); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
 
             					newLeafNode(otherlv_0, grammarAccess.getIntVariableNotEqualsAccess().getKeyIntVariableCrossReference_0_0());
             				
@@ -11020,15 +8855,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,69,FOLLOW_42); 
+            otherlv_1=(Token)match(input,67,FOLLOW_42); 
 
             			newLeafNode(otherlv_1, grammarAccess.getIntVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4656:3: ( (lv_value_2_0= RULE_INT ) )
-            // InternalTestgeneratorDSL.g:4657:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3711:3: ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:3712:4: (lv_value_2_0= RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:4657:4: (lv_value_2_0= RULE_INT )
-            // InternalTestgeneratorDSL.g:4658:5: lv_value_2_0= RULE_INT
+            // InternalTestgeneratorDSL.g:3712:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:3713:5: lv_value_2_0= RULE_INT
             {
             lv_value_2_0=(Token)match(input,RULE_INT,FOLLOW_2); 
 
@@ -11073,7 +8908,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleBooleanVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4678:1: entryRuleBooleanVariableNotEquals returns [EObject current=null] : iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF ;
+    // InternalTestgeneratorDSL.g:3733:1: entryRuleBooleanVariableNotEquals returns [EObject current=null] : iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF ;
     public final EObject entryRuleBooleanVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -11081,8 +8916,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4678:65: (iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF )
-            // InternalTestgeneratorDSL.g:4679:2: iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF
+            // InternalTestgeneratorDSL.g:3733:65: (iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF )
+            // InternalTestgeneratorDSL.g:3734:2: iv_ruleBooleanVariableNotEquals= ruleBooleanVariableNotEquals EOF
             {
              newCompositeNode(grammarAccess.getBooleanVariableNotEqualsRule()); 
             pushFollow(FOLLOW_1);
@@ -11109,7 +8944,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanVariableNotEquals"
-    // InternalTestgeneratorDSL.g:4685:1: ruleBooleanVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) ) ;
+    // InternalTestgeneratorDSL.g:3740:1: ruleBooleanVariableNotEquals returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) ) ;
     public final EObject ruleBooleanVariableNotEquals() throws RecognitionException {
         EObject current = null;
 
@@ -11122,24 +8957,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4691:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) ) )
-            // InternalTestgeneratorDSL.g:4692:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3746:2: ( ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) ) )
+            // InternalTestgeneratorDSL.g:3747:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) )
             {
-            // InternalTestgeneratorDSL.g:4692:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) )
-            // InternalTestgeneratorDSL.g:4693:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3747:2: ( ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:3748:3: ( (otherlv_0= RULE_ID ) ) otherlv_1= '!=' ( (lv_value_2_0= ruleBoolean ) )
             {
-            // InternalTestgeneratorDSL.g:4693:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4694:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3748:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3749:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4694:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4695:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3749:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3750:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getBooleanVariableNotEqualsRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_64); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_63); 
 
             					newLeafNode(otherlv_0, grammarAccess.getBooleanVariableNotEqualsAccess().getKeyBooleanVariableCrossReference_0_0());
             				
@@ -11149,15 +8984,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_1=(Token)match(input,69,FOLLOW_44); 
+            otherlv_1=(Token)match(input,67,FOLLOW_44); 
 
             			newLeafNode(otherlv_1, grammarAccess.getBooleanVariableNotEqualsAccess().getExclamationMarkEqualsSignKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:4710:3: ( (lv_value_2_0= ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:4711:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3765:3: ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:3766:4: (lv_value_2_0= ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:4711:4: (lv_value_2_0= ruleBoolean )
-            // InternalTestgeneratorDSL.g:4712:5: lv_value_2_0= ruleBoolean
+            // InternalTestgeneratorDSL.g:3766:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:3767:5: lv_value_2_0= ruleBoolean
             {
 
             					newCompositeNode(grammarAccess.getBooleanVariableNotEqualsAccess().getValueBooleanEnumRuleCall_2_0());
@@ -11207,7 +9042,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleMock"
-    // InternalTestgeneratorDSL.g:4733:1: entryRuleMock returns [EObject current=null] : iv_ruleMock= ruleMock EOF ;
+    // InternalTestgeneratorDSL.g:3788:1: entryRuleMock returns [EObject current=null] : iv_ruleMock= ruleMock EOF ;
     public final EObject entryRuleMock() throws RecognitionException {
         EObject current = null;
 
@@ -11215,8 +9050,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4733:45: (iv_ruleMock= ruleMock EOF )
-            // InternalTestgeneratorDSL.g:4734:2: iv_ruleMock= ruleMock EOF
+            // InternalTestgeneratorDSL.g:3788:45: (iv_ruleMock= ruleMock EOF )
+            // InternalTestgeneratorDSL.g:3789:2: iv_ruleMock= ruleMock EOF
             {
              newCompositeNode(grammarAccess.getMockRule()); 
             pushFollow(FOLLOW_1);
@@ -11243,7 +9078,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleMock"
-    // InternalTestgeneratorDSL.g:4740:1: ruleMock returns [EObject current=null] : (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock ) ;
+    // InternalTestgeneratorDSL.g:3795:1: ruleMock returns [EObject current=null] : (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock ) ;
     public final EObject ruleMock() throws RecognitionException {
         EObject current = null;
 
@@ -11256,28 +9091,28 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4746:2: ( (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock ) )
-            // InternalTestgeneratorDSL.g:4747:2: (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock )
+            // InternalTestgeneratorDSL.g:3801:2: ( (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock ) )
+            // InternalTestgeneratorDSL.g:3802:2: (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock )
             {
-            // InternalTestgeneratorDSL.g:4747:2: (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock )
-            int alt100=2;
-            int LA100_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3802:2: (this_ExternalServiceMock_0= ruleExternalServiceMock | this_DelegateMock_1= ruleDelegateMock )
+            int alt59=2;
+            int LA59_0 = input.LA(1);
 
-            if ( (LA100_0==70) ) {
-                alt100=1;
+            if ( (LA59_0==68) ) {
+                alt59=1;
             }
-            else if ( (LA100_0==72) ) {
-                alt100=2;
+            else if ( (LA59_0==70) ) {
+                alt59=2;
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 100, 0, input);
+                    new NoViableAltException("", 59, 0, input);
 
                 throw nvae;
             }
-            switch (alt100) {
+            switch (alt59) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4748:3: this_ExternalServiceMock_0= ruleExternalServiceMock
+                    // InternalTestgeneratorDSL.g:3803:3: this_ExternalServiceMock_0= ruleExternalServiceMock
                     {
 
                     			newCompositeNode(grammarAccess.getMockAccess().getExternalServiceMockParserRuleCall_0());
@@ -11295,7 +9130,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:4757:3: this_DelegateMock_1= ruleDelegateMock
+                    // InternalTestgeneratorDSL.g:3812:3: this_DelegateMock_1= ruleDelegateMock
                     {
 
                     			newCompositeNode(grammarAccess.getMockAccess().getDelegateMockParserRuleCall_1());
@@ -11335,7 +9170,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleMockReference"
-    // InternalTestgeneratorDSL.g:4769:1: entryRuleMockReference returns [EObject current=null] : iv_ruleMockReference= ruleMockReference EOF ;
+    // InternalTestgeneratorDSL.g:3824:1: entryRuleMockReference returns [EObject current=null] : iv_ruleMockReference= ruleMockReference EOF ;
     public final EObject entryRuleMockReference() throws RecognitionException {
         EObject current = null;
 
@@ -11343,8 +9178,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4769:54: (iv_ruleMockReference= ruleMockReference EOF )
-            // InternalTestgeneratorDSL.g:4770:2: iv_ruleMockReference= ruleMockReference EOF
+            // InternalTestgeneratorDSL.g:3824:54: (iv_ruleMockReference= ruleMockReference EOF )
+            // InternalTestgeneratorDSL.g:3825:2: iv_ruleMockReference= ruleMockReference EOF
             {
              newCompositeNode(grammarAccess.getMockReferenceRule()); 
             pushFollow(FOLLOW_1);
@@ -11371,7 +9206,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleMockReference"
-    // InternalTestgeneratorDSL.g:4776:1: ruleMockReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
+    // InternalTestgeneratorDSL.g:3831:1: ruleMockReference returns [EObject current=null] : ( (otherlv_0= RULE_ID ) ) ;
     public final EObject ruleMockReference() throws RecognitionException {
         EObject current = null;
 
@@ -11381,14 +9216,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4782:2: ( ( (otherlv_0= RULE_ID ) ) )
-            // InternalTestgeneratorDSL.g:4783:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3837:2: ( ( (otherlv_0= RULE_ID ) ) )
+            // InternalTestgeneratorDSL.g:3838:2: ( (otherlv_0= RULE_ID ) )
             {
-            // InternalTestgeneratorDSL.g:4783:2: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4784:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3838:2: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3839:3: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4784:3: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4785:4: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3839:3: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3840:4: otherlv_0= RULE_ID
             {
 
             				if (current==null) {
@@ -11425,7 +9260,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleExternalServiceMock"
-    // InternalTestgeneratorDSL.g:4799:1: entryRuleExternalServiceMock returns [EObject current=null] : iv_ruleExternalServiceMock= ruleExternalServiceMock EOF ;
+    // InternalTestgeneratorDSL.g:3854:1: entryRuleExternalServiceMock returns [EObject current=null] : iv_ruleExternalServiceMock= ruleExternalServiceMock EOF ;
     public final EObject entryRuleExternalServiceMock() throws RecognitionException {
         EObject current = null;
 
@@ -11433,8 +9268,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4799:60: (iv_ruleExternalServiceMock= ruleExternalServiceMock EOF )
-            // InternalTestgeneratorDSL.g:4800:2: iv_ruleExternalServiceMock= ruleExternalServiceMock EOF
+            // InternalTestgeneratorDSL.g:3854:60: (iv_ruleExternalServiceMock= ruleExternalServiceMock EOF )
+            // InternalTestgeneratorDSL.g:3855:2: iv_ruleExternalServiceMock= ruleExternalServiceMock EOF
             {
              newCompositeNode(grammarAccess.getExternalServiceMockRule()); 
             pushFollow(FOLLOW_1);
@@ -11461,7 +9296,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleExternalServiceMock"
-    // InternalTestgeneratorDSL.g:4806:1: ruleExternalServiceMock returns [EObject current=null] : (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:3861:1: ruleExternalServiceMock returns [EObject current=null] : (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleExternalServiceMock() throws RecognitionException {
         EObject current = null;
 
@@ -11482,21 +9317,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4812:2: ( (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:4813:2: (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3867:2: ( (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:3868:2: (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:4813:2: (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:4814:3: otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:3868:2: (otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3869:3: otherlv_0= 'ExternalServiceMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' otherlv_3= 'topic' ( (lv_externalTopic_4_0= ruleExternalTopicReference ) ) ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )? this_DECLARATION_FINISHED_8= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,70,FOLLOW_4); 
+            otherlv_0=(Token)match(input,68,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getExternalServiceMockAccess().getExternalServiceMockKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:4818:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4819:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3873:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3874:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4819:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4820:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3874:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3875:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_52); 
 
@@ -11518,19 +9353,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_2=(Token)match(input,58,FOLLOW_65); 
+            otherlv_2=(Token)match(input,56,FOLLOW_64); 
 
             			newLeafNode(otherlv_2, grammarAccess.getExternalServiceMockAccess().getForKeyword_2());
             		
-            otherlv_3=(Token)match(input,71,FOLLOW_4); 
+            otherlv_3=(Token)match(input,69,FOLLOW_4); 
 
             			newLeafNode(otherlv_3, grammarAccess.getExternalServiceMockAccess().getTopicKeyword_3());
             		
-            // InternalTestgeneratorDSL.g:4844:3: ( (lv_externalTopic_4_0= ruleExternalTopicReference ) )
-            // InternalTestgeneratorDSL.g:4845:4: (lv_externalTopic_4_0= ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:3899:3: ( (lv_externalTopic_4_0= ruleExternalTopicReference ) )
+            // InternalTestgeneratorDSL.g:3900:4: (lv_externalTopic_4_0= ruleExternalTopicReference )
             {
-            // InternalTestgeneratorDSL.g:4845:4: (lv_externalTopic_4_0= ruleExternalTopicReference )
-            // InternalTestgeneratorDSL.g:4846:5: lv_externalTopic_4_0= ruleExternalTopicReference
+            // InternalTestgeneratorDSL.g:3900:4: (lv_externalTopic_4_0= ruleExternalTopicReference )
+            // InternalTestgeneratorDSL.g:3901:5: lv_externalTopic_4_0= ruleExternalTopicReference
             {
 
             					newCompositeNode(grammarAccess.getExternalServiceMockAccess().getExternalTopicExternalTopicReferenceParserRuleCall_4_0());
@@ -11557,27 +9392,27 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:4863:3: ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )?
-            int alt102=2;
-            int LA102_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:3918:3: ( ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )* )?
+            int alt61=2;
+            int LA61_0 = input.LA(1);
 
-            if ( (LA102_0==17) ) {
-                alt102=1;
+            if ( (LA61_0==17) ) {
+                alt61=1;
             }
-            switch (alt102) {
+            switch (alt61) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:4864:4: ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )*
+                    // InternalTestgeneratorDSL.g:3919:4: ( (lv_mockingRules_5_0= ruleMockingRule ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:4864:4: ( (lv_mockingRules_5_0= ruleMockingRule ) )
-                    // InternalTestgeneratorDSL.g:4865:5: (lv_mockingRules_5_0= ruleMockingRule )
+                    // InternalTestgeneratorDSL.g:3919:4: ( (lv_mockingRules_5_0= ruleMockingRule ) )
+                    // InternalTestgeneratorDSL.g:3920:5: (lv_mockingRules_5_0= ruleMockingRule )
                     {
-                    // InternalTestgeneratorDSL.g:4865:5: (lv_mockingRules_5_0= ruleMockingRule )
-                    // InternalTestgeneratorDSL.g:4866:6: lv_mockingRules_5_0= ruleMockingRule
+                    // InternalTestgeneratorDSL.g:3920:5: (lv_mockingRules_5_0= ruleMockingRule )
+                    // InternalTestgeneratorDSL.g:3921:6: lv_mockingRules_5_0= ruleMockingRule
                     {
 
                     						newCompositeNode(grammarAccess.getExternalServiceMockAccess().getMockingRulesMockingRuleParserRuleCall_5_0_0());
                     					
-                    pushFollow(FOLLOW_66);
+                    pushFollow(FOLLOW_65);
                     lv_mockingRules_5_0=ruleMockingRule();
 
                     state._fsp--;
@@ -11599,35 +9434,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:4883:4: (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )*
-                    loop101:
+                    // InternalTestgeneratorDSL.g:3938:4: (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) ) )*
+                    loop60:
                     do {
-                        int alt101=2;
-                        int LA101_0 = input.LA(1);
+                        int alt60=2;
+                        int LA60_0 = input.LA(1);
 
-                        if ( (LA101_0==RULE_SEPARATOR) ) {
-                            alt101=1;
+                        if ( (LA60_0==RULE_SEPARATOR) ) {
+                            alt60=1;
                         }
 
 
-                        switch (alt101) {
+                        switch (alt60) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:4884:5: this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) )
+                    	    // InternalTestgeneratorDSL.g:3939:5: this_SEPARATOR_6= RULE_SEPARATOR ( (lv_mockingRules_7_0= ruleMockingRule ) )
                     	    {
                     	    this_SEPARATOR_6=(Token)match(input,RULE_SEPARATOR,FOLLOW_5); 
 
                     	    					newLeafNode(this_SEPARATOR_6, grammarAccess.getExternalServiceMockAccess().getSEPARATORTerminalRuleCall_5_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:4888:5: ( (lv_mockingRules_7_0= ruleMockingRule ) )
-                    	    // InternalTestgeneratorDSL.g:4889:6: (lv_mockingRules_7_0= ruleMockingRule )
+                    	    // InternalTestgeneratorDSL.g:3943:5: ( (lv_mockingRules_7_0= ruleMockingRule ) )
+                    	    // InternalTestgeneratorDSL.g:3944:6: (lv_mockingRules_7_0= ruleMockingRule )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:4889:6: (lv_mockingRules_7_0= ruleMockingRule )
-                    	    // InternalTestgeneratorDSL.g:4890:7: lv_mockingRules_7_0= ruleMockingRule
+                    	    // InternalTestgeneratorDSL.g:3944:6: (lv_mockingRules_7_0= ruleMockingRule )
+                    	    // InternalTestgeneratorDSL.g:3945:7: lv_mockingRules_7_0= ruleMockingRule
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getExternalServiceMockAccess().getMockingRulesMockingRuleParserRuleCall_5_1_1_0());
                     	    						
-                    	    pushFollow(FOLLOW_66);
+                    	    pushFollow(FOLLOW_65);
                     	    lv_mockingRules_7_0=ruleMockingRule();
 
                     	    state._fsp--;
@@ -11654,7 +9489,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop101;
+                    	    break loop60;
                         }
                     } while (true);
 
@@ -11691,7 +9526,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleDelegateMock"
-    // InternalTestgeneratorDSL.g:4917:1: entryRuleDelegateMock returns [EObject current=null] : iv_ruleDelegateMock= ruleDelegateMock EOF ;
+    // InternalTestgeneratorDSL.g:3972:1: entryRuleDelegateMock returns [EObject current=null] : iv_ruleDelegateMock= ruleDelegateMock EOF ;
     public final EObject entryRuleDelegateMock() throws RecognitionException {
         EObject current = null;
 
@@ -11699,8 +9534,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:4917:53: (iv_ruleDelegateMock= ruleDelegateMock EOF )
-            // InternalTestgeneratorDSL.g:4918:2: iv_ruleDelegateMock= ruleDelegateMock EOF
+            // InternalTestgeneratorDSL.g:3972:53: (iv_ruleDelegateMock= ruleDelegateMock EOF )
+            // InternalTestgeneratorDSL.g:3973:2: iv_ruleDelegateMock= ruleDelegateMock EOF
             {
              newCompositeNode(grammarAccess.getDelegateMockRule()); 
             pushFollow(FOLLOW_1);
@@ -11727,7 +9562,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleDelegateMock"
-    // InternalTestgeneratorDSL.g:4924:1: ruleDelegateMock returns [EObject current=null] : (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
+    // InternalTestgeneratorDSL.g:3979:1: ruleDelegateMock returns [EObject current=null] : (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) ;
     public final EObject ruleDelegateMock() throws RecognitionException {
         EObject current = null;
 
@@ -11750,21 +9585,21 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:4930:2: ( (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
-            // InternalTestgeneratorDSL.g:4931:2: (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3985:2: ( (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED ) )
+            // InternalTestgeneratorDSL.g:3986:2: (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
             {
-            // InternalTestgeneratorDSL.g:4931:2: (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
-            // InternalTestgeneratorDSL.g:4932:3: otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
+            // InternalTestgeneratorDSL.g:3986:2: (otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED )
+            // InternalTestgeneratorDSL.g:3987:3: otherlv_0= 'DelegateMock' ( (lv_name_1_0= RULE_ID ) ) otherlv_2= 'for' ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) ) otherlv_4= 'with' otherlv_5= 'delegate' ( (lv_delegateClass_6_0= RULE_STRING ) ) ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )? this_DECLARATION_FINISHED_10= RULE_DECLARATION_FINISHED
             {
-            otherlv_0=(Token)match(input,72,FOLLOW_4); 
+            otherlv_0=(Token)match(input,70,FOLLOW_4); 
 
             			newLeafNode(otherlv_0, grammarAccess.getDelegateMockAccess().getDelegateMockKeyword_0());
             		
-            // InternalTestgeneratorDSL.g:4936:3: ( (lv_name_1_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:4937:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3991:3: ( (lv_name_1_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:3992:4: (lv_name_1_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:4937:4: (lv_name_1_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:4938:5: lv_name_1_0= RULE_ID
+            // InternalTestgeneratorDSL.g:3992:4: (lv_name_1_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:3993:5: lv_name_1_0= RULE_ID
             {
             lv_name_1_0=(Token)match(input,RULE_ID,FOLLOW_52); 
 
@@ -11786,15 +9621,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_2=(Token)match(input,58,FOLLOW_4); 
+            otherlv_2=(Token)match(input,56,FOLLOW_4); 
 
             			newLeafNode(otherlv_2, grammarAccess.getDelegateMockAccess().getForKeyword_2());
             		
-            // InternalTestgeneratorDSL.g:4958:3: ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) )
-            // InternalTestgeneratorDSL.g:4959:4: (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference )
+            // InternalTestgeneratorDSL.g:4013:3: ( (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference ) )
+            // InternalTestgeneratorDSL.g:4014:4: (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference )
             {
-            // InternalTestgeneratorDSL.g:4959:4: (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference )
-            // InternalTestgeneratorDSL.g:4960:5: lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference
+            // InternalTestgeneratorDSL.g:4014:4: (lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference )
+            // InternalTestgeneratorDSL.g:4015:5: lv_serviceTaskReference_3_0= ruleDelegateServiceTaskReference
             {
 
             					newCompositeNode(grammarAccess.getDelegateMockAccess().getServiceTaskReferenceDelegateServiceTaskReferenceParserRuleCall_3_0());
@@ -11821,19 +9656,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_4=(Token)match(input,17,FOLLOW_33); 
+            otherlv_4=(Token)match(input,17,FOLLOW_29); 
 
             			newLeafNode(otherlv_4, grammarAccess.getDelegateMockAccess().getWithKeyword_4());
             		
-            otherlv_5=(Token)match(input,37,FOLLOW_7); 
+            otherlv_5=(Token)match(input,33,FOLLOW_7); 
 
             			newLeafNode(otherlv_5, grammarAccess.getDelegateMockAccess().getDelegateKeyword_5());
             		
-            // InternalTestgeneratorDSL.g:4985:3: ( (lv_delegateClass_6_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:4986:4: (lv_delegateClass_6_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4040:3: ( (lv_delegateClass_6_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4041:4: (lv_delegateClass_6_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:4986:4: (lv_delegateClass_6_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:4987:5: lv_delegateClass_6_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:4041:4: (lv_delegateClass_6_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4042:5: lv_delegateClass_6_0= RULE_STRING
             {
             lv_delegateClass_6_0=(Token)match(input,RULE_STRING,FOLLOW_10); 
 
@@ -11855,27 +9690,27 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5003:3: ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )?
-            int alt104=2;
-            int LA104_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4058:3: ( ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )* )?
+            int alt63=2;
+            int LA63_0 = input.LA(1);
 
-            if ( (LA104_0==17) ) {
-                alt104=1;
+            if ( (LA63_0==17) ) {
+                alt63=1;
             }
-            switch (alt104) {
+            switch (alt63) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5004:4: ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )*
+                    // InternalTestgeneratorDSL.g:4059:4: ( (lv_manualMocks_7_0= ruleManualMock ) ) (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:5004:4: ( (lv_manualMocks_7_0= ruleManualMock ) )
-                    // InternalTestgeneratorDSL.g:5005:5: (lv_manualMocks_7_0= ruleManualMock )
+                    // InternalTestgeneratorDSL.g:4059:4: ( (lv_manualMocks_7_0= ruleManualMock ) )
+                    // InternalTestgeneratorDSL.g:4060:5: (lv_manualMocks_7_0= ruleManualMock )
                     {
-                    // InternalTestgeneratorDSL.g:5005:5: (lv_manualMocks_7_0= ruleManualMock )
-                    // InternalTestgeneratorDSL.g:5006:6: lv_manualMocks_7_0= ruleManualMock
+                    // InternalTestgeneratorDSL.g:4060:5: (lv_manualMocks_7_0= ruleManualMock )
+                    // InternalTestgeneratorDSL.g:4061:6: lv_manualMocks_7_0= ruleManualMock
                     {
 
                     						newCompositeNode(grammarAccess.getDelegateMockAccess().getManualMocksManualMockParserRuleCall_7_0_0());
                     					
-                    pushFollow(FOLLOW_66);
+                    pushFollow(FOLLOW_65);
                     lv_manualMocks_7_0=ruleManualMock();
 
                     state._fsp--;
@@ -11897,35 +9732,35 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:5023:4: (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )*
-                    loop103:
+                    // InternalTestgeneratorDSL.g:4078:4: (this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) ) )*
+                    loop62:
                     do {
-                        int alt103=2;
-                        int LA103_0 = input.LA(1);
+                        int alt62=2;
+                        int LA62_0 = input.LA(1);
 
-                        if ( (LA103_0==RULE_SEPARATOR) ) {
-                            alt103=1;
+                        if ( (LA62_0==RULE_SEPARATOR) ) {
+                            alt62=1;
                         }
 
 
-                        switch (alt103) {
+                        switch (alt62) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:5024:5: this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) )
+                    	    // InternalTestgeneratorDSL.g:4079:5: this_SEPARATOR_8= RULE_SEPARATOR ( (lv_manualMocks_9_0= ruleManualMock ) )
                     	    {
                     	    this_SEPARATOR_8=(Token)match(input,RULE_SEPARATOR,FOLLOW_5); 
 
                     	    					newLeafNode(this_SEPARATOR_8, grammarAccess.getDelegateMockAccess().getSEPARATORTerminalRuleCall_7_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:5028:5: ( (lv_manualMocks_9_0= ruleManualMock ) )
-                    	    // InternalTestgeneratorDSL.g:5029:6: (lv_manualMocks_9_0= ruleManualMock )
+                    	    // InternalTestgeneratorDSL.g:4083:5: ( (lv_manualMocks_9_0= ruleManualMock ) )
+                    	    // InternalTestgeneratorDSL.g:4084:6: (lv_manualMocks_9_0= ruleManualMock )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:5029:6: (lv_manualMocks_9_0= ruleManualMock )
-                    	    // InternalTestgeneratorDSL.g:5030:7: lv_manualMocks_9_0= ruleManualMock
+                    	    // InternalTestgeneratorDSL.g:4084:6: (lv_manualMocks_9_0= ruleManualMock )
+                    	    // InternalTestgeneratorDSL.g:4085:7: lv_manualMocks_9_0= ruleManualMock
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getDelegateMockAccess().getManualMocksManualMockParserRuleCall_7_1_1_0());
                     	    						
-                    	    pushFollow(FOLLOW_66);
+                    	    pushFollow(FOLLOW_65);
                     	    lv_manualMocks_9_0=ruleManualMock();
 
                     	    state._fsp--;
@@ -11952,7 +9787,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop103;
+                    	    break loop62;
                         }
                     } while (true);
 
@@ -11989,7 +9824,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleMockingRule"
-    // InternalTestgeneratorDSL.g:5057:1: entryRuleMockingRule returns [EObject current=null] : iv_ruleMockingRule= ruleMockingRule EOF ;
+    // InternalTestgeneratorDSL.g:4112:1: entryRuleMockingRule returns [EObject current=null] : iv_ruleMockingRule= ruleMockingRule EOF ;
     public final EObject entryRuleMockingRule() throws RecognitionException {
         EObject current = null;
 
@@ -11997,8 +9832,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5057:52: (iv_ruleMockingRule= ruleMockingRule EOF )
-            // InternalTestgeneratorDSL.g:5058:2: iv_ruleMockingRule= ruleMockingRule EOF
+            // InternalTestgeneratorDSL.g:4112:52: (iv_ruleMockingRule= ruleMockingRule EOF )
+            // InternalTestgeneratorDSL.g:4113:2: iv_ruleMockingRule= ruleMockingRule EOF
             {
              newCompositeNode(grammarAccess.getMockingRuleRule()); 
             pushFollow(FOLLOW_1);
@@ -12025,7 +9860,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleMockingRule"
-    // InternalTestgeneratorDSL.g:5064:1: ruleMockingRule returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED ) ;
+    // InternalTestgeneratorDSL.g:4119:1: ruleMockingRule returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED ) ;
     public final EObject ruleMockingRule() throws RecognitionException {
         EObject current = null;
 
@@ -12053,48 +9888,48 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5070:2: ( (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED ) )
-            // InternalTestgeneratorDSL.g:5071:2: (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:4125:2: ( (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED ) )
+            // InternalTestgeneratorDSL.g:4126:2: (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED )
             {
-            // InternalTestgeneratorDSL.g:5071:2: (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED )
-            // InternalTestgeneratorDSL.g:5072:3: otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED
+            // InternalTestgeneratorDSL.g:4126:2: (otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED )
+            // InternalTestgeneratorDSL.g:4127:3: otherlv_0= 'with' otherlv_1= 'rule' this_ASSOCIATION_2= RULE_ASSOCIATION otherlv_3= 'if' this_LIST_OPEN_4= RULE_LIST_OPEN ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )? this_LIST_CLOSED_8= RULE_LIST_CLOSED otherlv_9= 'set' this_LIST_OPEN_10= RULE_LIST_OPEN ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )? this_LIST_CLOSED_14= RULE_LIST_CLOSED
             {
-            otherlv_0=(Token)match(input,17,FOLLOW_67); 
+            otherlv_0=(Token)match(input,17,FOLLOW_66); 
 
             			newLeafNode(otherlv_0, grammarAccess.getMockingRuleAccess().getWithKeyword_0());
             		
-            otherlv_1=(Token)match(input,73,FOLLOW_12); 
+            otherlv_1=(Token)match(input,71,FOLLOW_12); 
 
             			newLeafNode(otherlv_1, grammarAccess.getMockingRuleAccess().getRuleKeyword_1());
             		
-            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_68); 
+            this_ASSOCIATION_2=(Token)match(input,RULE_ASSOCIATION,FOLLOW_67); 
 
             			newLeafNode(this_ASSOCIATION_2, grammarAccess.getMockingRuleAccess().getASSOCIATIONTerminalRuleCall_2());
             		
-            otherlv_3=(Token)match(input,74,FOLLOW_13); 
+            otherlv_3=(Token)match(input,72,FOLLOW_13); 
 
             			newLeafNode(otherlv_3, grammarAccess.getMockingRuleAccess().getIfKeyword_3());
             		
-            this_LIST_OPEN_4=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+            this_LIST_OPEN_4=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
             			newLeafNode(this_LIST_OPEN_4, grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_4());
             		
-            // InternalTestgeneratorDSL.g:5092:3: ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )?
-            int alt106=2;
-            int LA106_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4147:3: ( ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )* )?
+            int alt65=2;
+            int LA65_0 = input.LA(1);
 
-            if ( (LA106_0==RULE_ID) ) {
-                alt106=1;
+            if ( (LA65_0==RULE_ID) ) {
+                alt65=1;
             }
-            switch (alt106) {
+            switch (alt65) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5093:4: ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )*
+                    // InternalTestgeneratorDSL.g:4148:4: ( (lv_comparisons_5_0= ruleCompare ) ) (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:5093:4: ( (lv_comparisons_5_0= ruleCompare ) )
-                    // InternalTestgeneratorDSL.g:5094:5: (lv_comparisons_5_0= ruleCompare )
+                    // InternalTestgeneratorDSL.g:4148:4: ( (lv_comparisons_5_0= ruleCompare ) )
+                    // InternalTestgeneratorDSL.g:4149:5: (lv_comparisons_5_0= ruleCompare )
                     {
-                    // InternalTestgeneratorDSL.g:5094:5: (lv_comparisons_5_0= ruleCompare )
-                    // InternalTestgeneratorDSL.g:5095:6: lv_comparisons_5_0= ruleCompare
+                    // InternalTestgeneratorDSL.g:4149:5: (lv_comparisons_5_0= ruleCompare )
+                    // InternalTestgeneratorDSL.g:4150:6: lv_comparisons_5_0= ruleCompare
                     {
 
                     						newCompositeNode(grammarAccess.getMockingRuleAccess().getComparisonsCompareParserRuleCall_5_0_0());
@@ -12121,30 +9956,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:5112:4: (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )*
-                    loop105:
+                    // InternalTestgeneratorDSL.g:4167:4: (this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) ) )*
+                    loop64:
                     do {
-                        int alt105=2;
-                        int LA105_0 = input.LA(1);
+                        int alt64=2;
+                        int LA64_0 = input.LA(1);
 
-                        if ( (LA105_0==RULE_SEPARATOR) ) {
-                            alt105=1;
+                        if ( (LA64_0==RULE_SEPARATOR) ) {
+                            alt64=1;
                         }
 
 
-                        switch (alt105) {
+                        switch (alt64) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:5113:5: this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) )
+                    	    // InternalTestgeneratorDSL.g:4168:5: this_SEPARATOR_6= RULE_SEPARATOR ( (lv_comparisons_7_0= ruleCompare ) )
                     	    {
                     	    this_SEPARATOR_6=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                     	    					newLeafNode(this_SEPARATOR_6, grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_5_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:5117:5: ( (lv_comparisons_7_0= ruleCompare ) )
-                    	    // InternalTestgeneratorDSL.g:5118:6: (lv_comparisons_7_0= ruleCompare )
+                    	    // InternalTestgeneratorDSL.g:4172:5: ( (lv_comparisons_7_0= ruleCompare ) )
+                    	    // InternalTestgeneratorDSL.g:4173:6: (lv_comparisons_7_0= ruleCompare )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:5118:6: (lv_comparisons_7_0= ruleCompare )
-                    	    // InternalTestgeneratorDSL.g:5119:7: lv_comparisons_7_0= ruleCompare
+                    	    // InternalTestgeneratorDSL.g:4173:6: (lv_comparisons_7_0= ruleCompare )
+                    	    // InternalTestgeneratorDSL.g:4174:7: lv_comparisons_7_0= ruleCompare
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getMockingRuleAccess().getComparisonsCompareParserRuleCall_5_1_1_0());
@@ -12176,7 +10011,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop105;
+                    	    break loop64;
                         }
                     } while (true);
 
@@ -12186,34 +10021,34 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            this_LIST_CLOSED_8=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_69); 
+            this_LIST_CLOSED_8=(Token)match(input,RULE_LIST_CLOSED,FOLLOW_68); 
 
             			newLeafNode(this_LIST_CLOSED_8, grammarAccess.getMockingRuleAccess().getLIST_CLOSEDTerminalRuleCall_6());
             		
-            otherlv_9=(Token)match(input,75,FOLLOW_13); 
+            otherlv_9=(Token)match(input,73,FOLLOW_13); 
 
             			newLeafNode(otherlv_9, grammarAccess.getMockingRuleAccess().getSetKeyword_7());
             		
-            this_LIST_OPEN_10=(Token)match(input,RULE_LIST_OPEN,FOLLOW_21); 
+            this_LIST_OPEN_10=(Token)match(input,RULE_LIST_OPEN,FOLLOW_20); 
 
             			newLeafNode(this_LIST_OPEN_10, grammarAccess.getMockingRuleAccess().getLIST_OPENTerminalRuleCall_8());
             		
-            // InternalTestgeneratorDSL.g:5150:3: ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )?
-            int alt108=2;
-            int LA108_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4205:3: ( ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )* )?
+            int alt67=2;
+            int LA67_0 = input.LA(1);
 
-            if ( (LA108_0==RULE_ID) ) {
-                alt108=1;
+            if ( (LA67_0==RULE_ID) ) {
+                alt67=1;
             }
-            switch (alt108) {
+            switch (alt67) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5151:4: ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )*
+                    // InternalTestgeneratorDSL.g:4206:4: ( (lv_variables_11_0= ruleVariableDeclaration ) ) (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )*
                     {
-                    // InternalTestgeneratorDSL.g:5151:4: ( (lv_variables_11_0= ruleVariableDeclaration ) )
-                    // InternalTestgeneratorDSL.g:5152:5: (lv_variables_11_0= ruleVariableDeclaration )
+                    // InternalTestgeneratorDSL.g:4206:4: ( (lv_variables_11_0= ruleVariableDeclaration ) )
+                    // InternalTestgeneratorDSL.g:4207:5: (lv_variables_11_0= ruleVariableDeclaration )
                     {
-                    // InternalTestgeneratorDSL.g:5152:5: (lv_variables_11_0= ruleVariableDeclaration )
-                    // InternalTestgeneratorDSL.g:5153:6: lv_variables_11_0= ruleVariableDeclaration
+                    // InternalTestgeneratorDSL.g:4207:5: (lv_variables_11_0= ruleVariableDeclaration )
+                    // InternalTestgeneratorDSL.g:4208:6: lv_variables_11_0= ruleVariableDeclaration
                     {
 
                     						newCompositeNode(grammarAccess.getMockingRuleAccess().getVariablesVariableDeclarationParserRuleCall_9_0_0());
@@ -12240,30 +10075,30 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
                     }
 
-                    // InternalTestgeneratorDSL.g:5170:4: (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )*
-                    loop107:
+                    // InternalTestgeneratorDSL.g:4225:4: (this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) ) )*
+                    loop66:
                     do {
-                        int alt107=2;
-                        int LA107_0 = input.LA(1);
+                        int alt66=2;
+                        int LA66_0 = input.LA(1);
 
-                        if ( (LA107_0==RULE_SEPARATOR) ) {
-                            alt107=1;
+                        if ( (LA66_0==RULE_SEPARATOR) ) {
+                            alt66=1;
                         }
 
 
-                        switch (alt107) {
+                        switch (alt66) {
                     	case 1 :
-                    	    // InternalTestgeneratorDSL.g:5171:5: this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) )
+                    	    // InternalTestgeneratorDSL.g:4226:5: this_SEPARATOR_12= RULE_SEPARATOR ( (lv_variables_13_0= ruleVariableDeclaration ) )
                     	    {
                     	    this_SEPARATOR_12=(Token)match(input,RULE_SEPARATOR,FOLLOW_4); 
 
                     	    					newLeafNode(this_SEPARATOR_12, grammarAccess.getMockingRuleAccess().getSEPARATORTerminalRuleCall_9_1_0());
                     	    				
-                    	    // InternalTestgeneratorDSL.g:5175:5: ( (lv_variables_13_0= ruleVariableDeclaration ) )
-                    	    // InternalTestgeneratorDSL.g:5176:6: (lv_variables_13_0= ruleVariableDeclaration )
+                    	    // InternalTestgeneratorDSL.g:4230:5: ( (lv_variables_13_0= ruleVariableDeclaration ) )
+                    	    // InternalTestgeneratorDSL.g:4231:6: (lv_variables_13_0= ruleVariableDeclaration )
                     	    {
-                    	    // InternalTestgeneratorDSL.g:5176:6: (lv_variables_13_0= ruleVariableDeclaration )
-                    	    // InternalTestgeneratorDSL.g:5177:7: lv_variables_13_0= ruleVariableDeclaration
+                    	    // InternalTestgeneratorDSL.g:4231:6: (lv_variables_13_0= ruleVariableDeclaration )
+                    	    // InternalTestgeneratorDSL.g:4232:7: lv_variables_13_0= ruleVariableDeclaration
                     	    {
 
                     	    							newCompositeNode(grammarAccess.getMockingRuleAccess().getVariablesVariableDeclarationParserRuleCall_9_1_1_0());
@@ -12295,7 +10130,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     	    break;
 
                     	default :
-                    	    break loop107;
+                    	    break loop66;
                         }
                     } while (true);
 
@@ -12332,7 +10167,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleManualMock"
-    // InternalTestgeneratorDSL.g:5204:1: entryRuleManualMock returns [EObject current=null] : iv_ruleManualMock= ruleManualMock EOF ;
+    // InternalTestgeneratorDSL.g:4259:1: entryRuleManualMock returns [EObject current=null] : iv_ruleManualMock= ruleManualMock EOF ;
     public final EObject entryRuleManualMock() throws RecognitionException {
         EObject current = null;
 
@@ -12340,8 +10175,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5204:51: (iv_ruleManualMock= ruleManualMock EOF )
-            // InternalTestgeneratorDSL.g:5205:2: iv_ruleManualMock= ruleManualMock EOF
+            // InternalTestgeneratorDSL.g:4259:51: (iv_ruleManualMock= ruleManualMock EOF )
+            // InternalTestgeneratorDSL.g:4260:2: iv_ruleManualMock= ruleManualMock EOF
             {
              newCompositeNode(grammarAccess.getManualMockRule()); 
             pushFollow(FOLLOW_1);
@@ -12368,7 +10203,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleManualMock"
-    // InternalTestgeneratorDSL.g:5211:1: ruleManualMock returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) ) ;
+    // InternalTestgeneratorDSL.g:4266:1: ruleManualMock returns [EObject current=null] : (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) ) ;
     public final EObject ruleManualMock() throws RecognitionException {
         EObject current = null;
 
@@ -12383,25 +10218,25 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5217:2: ( (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) ) )
-            // InternalTestgeneratorDSL.g:5218:2: (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:4272:2: ( (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) ) )
+            // InternalTestgeneratorDSL.g:4273:2: (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) )
             {
-            // InternalTestgeneratorDSL.g:5218:2: (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) )
-            // InternalTestgeneratorDSL.g:5219:3: otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4273:2: (otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:4274:3: otherlv_0= 'with' otherlv_1= 'manual' ( (lv_serviceName_2_0= RULE_STRING ) ) otherlv_3= 'by' otherlv_4= 'setter' ( (lv_setter_5_0= RULE_STRING ) )
             {
-            otherlv_0=(Token)match(input,17,FOLLOW_70); 
+            otherlv_0=(Token)match(input,17,FOLLOW_69); 
 
             			newLeafNode(otherlv_0, grammarAccess.getManualMockAccess().getWithKeyword_0());
             		
-            otherlv_1=(Token)match(input,76,FOLLOW_7); 
+            otherlv_1=(Token)match(input,74,FOLLOW_7); 
 
             			newLeafNode(otherlv_1, grammarAccess.getManualMockAccess().getManualKeyword_1());
             		
-            // InternalTestgeneratorDSL.g:5227:3: ( (lv_serviceName_2_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:5228:4: (lv_serviceName_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4282:3: ( (lv_serviceName_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4283:4: (lv_serviceName_2_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:5228:4: (lv_serviceName_2_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:5229:5: lv_serviceName_2_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:4283:4: (lv_serviceName_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4284:5: lv_serviceName_2_0= RULE_STRING
             {
             lv_serviceName_2_0=(Token)match(input,RULE_STRING,FOLLOW_47); 
 
@@ -12423,19 +10258,19 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            otherlv_3=(Token)match(input,52,FOLLOW_71); 
+            otherlv_3=(Token)match(input,50,FOLLOW_70); 
 
             			newLeafNode(otherlv_3, grammarAccess.getManualMockAccess().getByKeyword_3());
             		
-            otherlv_4=(Token)match(input,77,FOLLOW_7); 
+            otherlv_4=(Token)match(input,75,FOLLOW_7); 
 
             			newLeafNode(otherlv_4, grammarAccess.getManualMockAccess().getSetterKeyword_4());
             		
-            // InternalTestgeneratorDSL.g:5253:3: ( (lv_setter_5_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:5254:4: (lv_setter_5_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4308:3: ( (lv_setter_5_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4309:4: (lv_setter_5_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:5254:4: (lv_setter_5_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:5255:5: lv_setter_5_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:4309:4: (lv_setter_5_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4310:5: lv_setter_5_0= RULE_STRING
             {
             lv_setter_5_0=(Token)match(input,RULE_STRING,FOLLOW_2); 
 
@@ -12480,7 +10315,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleCompare"
-    // InternalTestgeneratorDSL.g:5275:1: entryRuleCompare returns [EObject current=null] : iv_ruleCompare= ruleCompare EOF ;
+    // InternalTestgeneratorDSL.g:4330:1: entryRuleCompare returns [EObject current=null] : iv_ruleCompare= ruleCompare EOF ;
     public final EObject entryRuleCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12488,8 +10323,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5275:48: (iv_ruleCompare= ruleCompare EOF )
-            // InternalTestgeneratorDSL.g:5276:2: iv_ruleCompare= ruleCompare EOF
+            // InternalTestgeneratorDSL.g:4330:48: (iv_ruleCompare= ruleCompare EOF )
+            // InternalTestgeneratorDSL.g:4331:2: iv_ruleCompare= ruleCompare EOF
             {
              newCompositeNode(grammarAccess.getCompareRule()); 
             pushFollow(FOLLOW_1);
@@ -12516,7 +10351,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleCompare"
-    // InternalTestgeneratorDSL.g:5282:1: ruleCompare returns [EObject current=null] : (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare ) ;
+    // InternalTestgeneratorDSL.g:4337:1: ruleCompare returns [EObject current=null] : (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare ) ;
     public final EObject ruleCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12531,82 +10366,82 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5288:2: ( (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare ) )
-            // InternalTestgeneratorDSL.g:5289:2: (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare )
+            // InternalTestgeneratorDSL.g:4343:2: ( (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare ) )
+            // InternalTestgeneratorDSL.g:4344:2: (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare )
             {
-            // InternalTestgeneratorDSL.g:5289:2: (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare )
-            int alt109=3;
-            int LA109_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4344:2: (this_StringCompare_0= ruleStringCompare | this_IntCompare_1= ruleIntCompare | this_BooleanCompare_2= ruleBooleanCompare )
+            int alt68=3;
+            int LA68_0 = input.LA(1);
 
-            if ( (LA109_0==RULE_ID) ) {
+            if ( (LA68_0==RULE_ID) ) {
                 switch ( input.LA(2) ) {
-                case 68:
+                case 66:
                     {
                     switch ( input.LA(3) ) {
                     case RULE_INT:
                         {
-                        alt109=2;
+                        alt68=2;
                         }
                         break;
-                    case 78:
-                    case 79:
+                    case 76:
+                    case 77:
                         {
-                        alt109=3;
+                        alt68=3;
                         }
                         break;
                     case RULE_STRING:
                         {
-                        alt109=1;
+                        alt68=1;
                         }
                         break;
                     default:
                         NoViableAltException nvae =
-                            new NoViableAltException("", 109, 2, input);
+                            new NoViableAltException("", 68, 2, input);
 
                         throw nvae;
                     }
 
                     }
                     break;
-                case 69:
+                case 67:
                     {
                     switch ( input.LA(3) ) {
                     case RULE_STRING:
                         {
-                        alt109=1;
+                        alt68=1;
                         }
                         break;
                     case RULE_INT:
                         {
-                        alt109=2;
+                        alt68=2;
                         }
                         break;
-                    case 78:
-                    case 79:
+                    case 76:
+                    case 77:
                         {
-                        alt109=3;
+                        alt68=3;
                         }
                         break;
                     default:
                         NoViableAltException nvae =
-                            new NoViableAltException("", 109, 3, input);
+                            new NoViableAltException("", 68, 3, input);
 
                         throw nvae;
                     }
 
                     }
                     break;
+                case 78:
+                case 79:
                 case 80:
                 case 81:
-                case 82:
-                case 83:
                     {
-                    alt109=2;
+                    alt68=2;
                     }
                     break;
                 default:
                     NoViableAltException nvae =
-                        new NoViableAltException("", 109, 1, input);
+                        new NoViableAltException("", 68, 1, input);
 
                     throw nvae;
                 }
@@ -12614,13 +10449,13 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 109, 0, input);
+                    new NoViableAltException("", 68, 0, input);
 
                 throw nvae;
             }
-            switch (alt109) {
+            switch (alt68) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5290:3: this_StringCompare_0= ruleStringCompare
+                    // InternalTestgeneratorDSL.g:4345:3: this_StringCompare_0= ruleStringCompare
                     {
 
                     			newCompositeNode(grammarAccess.getCompareAccess().getStringCompareParserRuleCall_0());
@@ -12638,7 +10473,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5299:3: this_IntCompare_1= ruleIntCompare
+                    // InternalTestgeneratorDSL.g:4354:3: this_IntCompare_1= ruleIntCompare
                     {
 
                     			newCompositeNode(grammarAccess.getCompareAccess().getIntCompareParserRuleCall_1());
@@ -12656,7 +10491,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:5308:3: this_BooleanCompare_2= ruleBooleanCompare
+                    // InternalTestgeneratorDSL.g:4363:3: this_BooleanCompare_2= ruleBooleanCompare
                     {
 
                     			newCompositeNode(grammarAccess.getCompareAccess().getBooleanCompareParserRuleCall_2());
@@ -12696,7 +10531,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleStringCompare"
-    // InternalTestgeneratorDSL.g:5320:1: entryRuleStringCompare returns [EObject current=null] : iv_ruleStringCompare= ruleStringCompare EOF ;
+    // InternalTestgeneratorDSL.g:4375:1: entryRuleStringCompare returns [EObject current=null] : iv_ruleStringCompare= ruleStringCompare EOF ;
     public final EObject entryRuleStringCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12704,8 +10539,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5320:54: (iv_ruleStringCompare= ruleStringCompare EOF )
-            // InternalTestgeneratorDSL.g:5321:2: iv_ruleStringCompare= ruleStringCompare EOF
+            // InternalTestgeneratorDSL.g:4375:54: (iv_ruleStringCompare= ruleStringCompare EOF )
+            // InternalTestgeneratorDSL.g:4376:2: iv_ruleStringCompare= ruleStringCompare EOF
             {
              newCompositeNode(grammarAccess.getStringCompareRule()); 
             pushFollow(FOLLOW_1);
@@ -12732,7 +10567,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringCompare"
-    // InternalTestgeneratorDSL.g:5327:1: ruleStringCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) ) ;
+    // InternalTestgeneratorDSL.g:4382:1: ruleStringCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) ) ;
     public final EObject ruleStringCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12745,24 +10580,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5333:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) ) )
-            // InternalTestgeneratorDSL.g:5334:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:4388:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) ) )
+            // InternalTestgeneratorDSL.g:4389:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) )
             {
-            // InternalTestgeneratorDSL.g:5334:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) )
-            // InternalTestgeneratorDSL.g:5335:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4389:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) ) )
+            // InternalTestgeneratorDSL.g:4390:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) ) ( (lv_value_2_0= RULE_STRING ) )
             {
-            // InternalTestgeneratorDSL.g:5335:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:5336:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4390:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:4391:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:5336:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:5337:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:4391:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4392:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getStringCompareRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_72); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_71); 
 
             					newLeafNode(otherlv_0, grammarAccess.getStringCompareAccess().getKeyStringVariableCrossReference_0_0());
             				
@@ -12772,11 +10607,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5348:3: ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:5349:4: (lv_compareSymbol_1_0= ruleStringCompareSymbol )
+            // InternalTestgeneratorDSL.g:4403:3: ( (lv_compareSymbol_1_0= ruleStringCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:4404:4: (lv_compareSymbol_1_0= ruleStringCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:5349:4: (lv_compareSymbol_1_0= ruleStringCompareSymbol )
-            // InternalTestgeneratorDSL.g:5350:5: lv_compareSymbol_1_0= ruleStringCompareSymbol
+            // InternalTestgeneratorDSL.g:4404:4: (lv_compareSymbol_1_0= ruleStringCompareSymbol )
+            // InternalTestgeneratorDSL.g:4405:5: lv_compareSymbol_1_0= ruleStringCompareSymbol
             {
 
             					newCompositeNode(grammarAccess.getStringCompareAccess().getCompareSymbolStringCompareSymbolEnumRuleCall_1_0());
@@ -12803,11 +10638,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5367:3: ( (lv_value_2_0= RULE_STRING ) )
-            // InternalTestgeneratorDSL.g:5368:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4422:3: ( (lv_value_2_0= RULE_STRING ) )
+            // InternalTestgeneratorDSL.g:4423:4: (lv_value_2_0= RULE_STRING )
             {
-            // InternalTestgeneratorDSL.g:5368:4: (lv_value_2_0= RULE_STRING )
-            // InternalTestgeneratorDSL.g:5369:5: lv_value_2_0= RULE_STRING
+            // InternalTestgeneratorDSL.g:4423:4: (lv_value_2_0= RULE_STRING )
+            // InternalTestgeneratorDSL.g:4424:5: lv_value_2_0= RULE_STRING
             {
             lv_value_2_0=(Token)match(input,RULE_STRING,FOLLOW_2); 
 
@@ -12852,7 +10687,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleIntCompare"
-    // InternalTestgeneratorDSL.g:5389:1: entryRuleIntCompare returns [EObject current=null] : iv_ruleIntCompare= ruleIntCompare EOF ;
+    // InternalTestgeneratorDSL.g:4444:1: entryRuleIntCompare returns [EObject current=null] : iv_ruleIntCompare= ruleIntCompare EOF ;
     public final EObject entryRuleIntCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12860,8 +10695,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5389:51: (iv_ruleIntCompare= ruleIntCompare EOF )
-            // InternalTestgeneratorDSL.g:5390:2: iv_ruleIntCompare= ruleIntCompare EOF
+            // InternalTestgeneratorDSL.g:4444:51: (iv_ruleIntCompare= ruleIntCompare EOF )
+            // InternalTestgeneratorDSL.g:4445:2: iv_ruleIntCompare= ruleIntCompare EOF
             {
              newCompositeNode(grammarAccess.getIntCompareRule()); 
             pushFollow(FOLLOW_1);
@@ -12888,7 +10723,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntCompare"
-    // InternalTestgeneratorDSL.g:5396:1: ruleIntCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) ) ;
+    // InternalTestgeneratorDSL.g:4451:1: ruleIntCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) ) ;
     public final EObject ruleIntCompare() throws RecognitionException {
         EObject current = null;
 
@@ -12901,24 +10736,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5402:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) ) )
-            // InternalTestgeneratorDSL.g:5403:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:4457:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) ) )
+            // InternalTestgeneratorDSL.g:4458:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) )
             {
-            // InternalTestgeneratorDSL.g:5403:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) )
-            // InternalTestgeneratorDSL.g:5404:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:4458:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) ) )
+            // InternalTestgeneratorDSL.g:4459:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) ) ( (lv_value_2_0= RULE_INT ) )
             {
-            // InternalTestgeneratorDSL.g:5404:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:5405:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4459:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:4460:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:5405:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:5406:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:4460:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4461:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getIntCompareRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_73); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_72); 
 
             					newLeafNode(otherlv_0, grammarAccess.getIntCompareAccess().getKeyIntVariableCrossReference_0_0());
             				
@@ -12928,11 +10763,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5417:3: ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:5418:4: (lv_compareSymbol_1_0= ruleIntCompareSymbol )
+            // InternalTestgeneratorDSL.g:4472:3: ( (lv_compareSymbol_1_0= ruleIntCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:4473:4: (lv_compareSymbol_1_0= ruleIntCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:5418:4: (lv_compareSymbol_1_0= ruleIntCompareSymbol )
-            // InternalTestgeneratorDSL.g:5419:5: lv_compareSymbol_1_0= ruleIntCompareSymbol
+            // InternalTestgeneratorDSL.g:4473:4: (lv_compareSymbol_1_0= ruleIntCompareSymbol )
+            // InternalTestgeneratorDSL.g:4474:5: lv_compareSymbol_1_0= ruleIntCompareSymbol
             {
 
             					newCompositeNode(grammarAccess.getIntCompareAccess().getCompareSymbolIntCompareSymbolEnumRuleCall_1_0());
@@ -12959,11 +10794,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5436:3: ( (lv_value_2_0= RULE_INT ) )
-            // InternalTestgeneratorDSL.g:5437:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:4491:3: ( (lv_value_2_0= RULE_INT ) )
+            // InternalTestgeneratorDSL.g:4492:4: (lv_value_2_0= RULE_INT )
             {
-            // InternalTestgeneratorDSL.g:5437:4: (lv_value_2_0= RULE_INT )
-            // InternalTestgeneratorDSL.g:5438:5: lv_value_2_0= RULE_INT
+            // InternalTestgeneratorDSL.g:4492:4: (lv_value_2_0= RULE_INT )
+            // InternalTestgeneratorDSL.g:4493:5: lv_value_2_0= RULE_INT
             {
             lv_value_2_0=(Token)match(input,RULE_INT,FOLLOW_2); 
 
@@ -13008,7 +10843,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "entryRuleBooleanCompare"
-    // InternalTestgeneratorDSL.g:5458:1: entryRuleBooleanCompare returns [EObject current=null] : iv_ruleBooleanCompare= ruleBooleanCompare EOF ;
+    // InternalTestgeneratorDSL.g:4513:1: entryRuleBooleanCompare returns [EObject current=null] : iv_ruleBooleanCompare= ruleBooleanCompare EOF ;
     public final EObject entryRuleBooleanCompare() throws RecognitionException {
         EObject current = null;
 
@@ -13016,8 +10851,8 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
         try {
-            // InternalTestgeneratorDSL.g:5458:55: (iv_ruleBooleanCompare= ruleBooleanCompare EOF )
-            // InternalTestgeneratorDSL.g:5459:2: iv_ruleBooleanCompare= ruleBooleanCompare EOF
+            // InternalTestgeneratorDSL.g:4513:55: (iv_ruleBooleanCompare= ruleBooleanCompare EOF )
+            // InternalTestgeneratorDSL.g:4514:2: iv_ruleBooleanCompare= ruleBooleanCompare EOF
             {
              newCompositeNode(grammarAccess.getBooleanCompareRule()); 
             pushFollow(FOLLOW_1);
@@ -13044,7 +10879,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanCompare"
-    // InternalTestgeneratorDSL.g:5465:1: ruleBooleanCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) ) ;
+    // InternalTestgeneratorDSL.g:4520:1: ruleBooleanCompare returns [EObject current=null] : ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) ) ;
     public final EObject ruleBooleanCompare() throws RecognitionException {
         EObject current = null;
 
@@ -13058,24 +10893,24 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5471:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) ) )
-            // InternalTestgeneratorDSL.g:5472:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:4526:2: ( ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) ) )
+            // InternalTestgeneratorDSL.g:4527:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) )
             {
-            // InternalTestgeneratorDSL.g:5472:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) )
-            // InternalTestgeneratorDSL.g:5473:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:4527:2: ( ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) ) )
+            // InternalTestgeneratorDSL.g:4528:3: ( (otherlv_0= RULE_ID ) ) ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) ) ( (lv_value_2_0= ruleBoolean ) )
             {
-            // InternalTestgeneratorDSL.g:5473:3: ( (otherlv_0= RULE_ID ) )
-            // InternalTestgeneratorDSL.g:5474:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4528:3: ( (otherlv_0= RULE_ID ) )
+            // InternalTestgeneratorDSL.g:4529:4: (otherlv_0= RULE_ID )
             {
-            // InternalTestgeneratorDSL.g:5474:4: (otherlv_0= RULE_ID )
-            // InternalTestgeneratorDSL.g:5475:5: otherlv_0= RULE_ID
+            // InternalTestgeneratorDSL.g:4529:4: (otherlv_0= RULE_ID )
+            // InternalTestgeneratorDSL.g:4530:5: otherlv_0= RULE_ID
             {
 
             					if (current==null) {
             						current = createModelElement(grammarAccess.getBooleanCompareRule());
             					}
             				
-            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_72); 
+            otherlv_0=(Token)match(input,RULE_ID,FOLLOW_71); 
 
             					newLeafNode(otherlv_0, grammarAccess.getBooleanCompareAccess().getKeyBooleanVariableCrossReference_0_0());
             				
@@ -13085,11 +10920,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5486:3: ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) )
-            // InternalTestgeneratorDSL.g:5487:4: (lv_compareSymbol_1_0= ruleBooleanCompareSymbol )
+            // InternalTestgeneratorDSL.g:4541:3: ( (lv_compareSymbol_1_0= ruleBooleanCompareSymbol ) )
+            // InternalTestgeneratorDSL.g:4542:4: (lv_compareSymbol_1_0= ruleBooleanCompareSymbol )
             {
-            // InternalTestgeneratorDSL.g:5487:4: (lv_compareSymbol_1_0= ruleBooleanCompareSymbol )
-            // InternalTestgeneratorDSL.g:5488:5: lv_compareSymbol_1_0= ruleBooleanCompareSymbol
+            // InternalTestgeneratorDSL.g:4542:4: (lv_compareSymbol_1_0= ruleBooleanCompareSymbol )
+            // InternalTestgeneratorDSL.g:4543:5: lv_compareSymbol_1_0= ruleBooleanCompareSymbol
             {
 
             					newCompositeNode(grammarAccess.getBooleanCompareAccess().getCompareSymbolBooleanCompareSymbolEnumRuleCall_1_0());
@@ -13116,11 +10951,11 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
             }
 
-            // InternalTestgeneratorDSL.g:5505:3: ( (lv_value_2_0= ruleBoolean ) )
-            // InternalTestgeneratorDSL.g:5506:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:4560:3: ( (lv_value_2_0= ruleBoolean ) )
+            // InternalTestgeneratorDSL.g:4561:4: (lv_value_2_0= ruleBoolean )
             {
-            // InternalTestgeneratorDSL.g:5506:4: (lv_value_2_0= ruleBoolean )
-            // InternalTestgeneratorDSL.g:5507:5: lv_value_2_0= ruleBoolean
+            // InternalTestgeneratorDSL.g:4561:4: (lv_value_2_0= ruleBoolean )
+            // InternalTestgeneratorDSL.g:4562:5: lv_value_2_0= ruleBoolean
             {
 
             					newCompositeNode(grammarAccess.getBooleanCompareAccess().getValueBooleanEnumRuleCall_2_0());
@@ -13170,7 +11005,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBoolean"
-    // InternalTestgeneratorDSL.g:5528:1: ruleBoolean returns [Enumerator current=null] : ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) ) ;
+    // InternalTestgeneratorDSL.g:4583:1: ruleBoolean returns [Enumerator current=null] : ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) ) ;
     public final Enumerator ruleBoolean() throws RecognitionException {
         Enumerator current = null;
 
@@ -13181,33 +11016,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5534:2: ( ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) ) )
-            // InternalTestgeneratorDSL.g:5535:2: ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) )
+            // InternalTestgeneratorDSL.g:4589:2: ( ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) ) )
+            // InternalTestgeneratorDSL.g:4590:2: ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) )
             {
-            // InternalTestgeneratorDSL.g:5535:2: ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) )
-            int alt110=2;
-            int LA110_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4590:2: ( (enumLiteral_0= 'true' ) | (enumLiteral_1= 'false' ) )
+            int alt69=2;
+            int LA69_0 = input.LA(1);
 
-            if ( (LA110_0==78) ) {
-                alt110=1;
+            if ( (LA69_0==76) ) {
+                alt69=1;
             }
-            else if ( (LA110_0==79) ) {
-                alt110=2;
+            else if ( (LA69_0==77) ) {
+                alt69=2;
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 110, 0, input);
+                    new NoViableAltException("", 69, 0, input);
 
                 throw nvae;
             }
-            switch (alt110) {
+            switch (alt69) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5536:3: (enumLiteral_0= 'true' )
+                    // InternalTestgeneratorDSL.g:4591:3: (enumLiteral_0= 'true' )
                     {
-                    // InternalTestgeneratorDSL.g:5536:3: (enumLiteral_0= 'true' )
-                    // InternalTestgeneratorDSL.g:5537:4: enumLiteral_0= 'true'
+                    // InternalTestgeneratorDSL.g:4591:3: (enumLiteral_0= 'true' )
+                    // InternalTestgeneratorDSL.g:4592:4: enumLiteral_0= 'true'
                     {
-                    enumLiteral_0=(Token)match(input,78,FOLLOW_2); 
+                    enumLiteral_0=(Token)match(input,76,FOLLOW_2); 
 
                     				current = grammarAccess.getBooleanAccess().getTRUEEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_0, grammarAccess.getBooleanAccess().getTRUEEnumLiteralDeclaration_0());
@@ -13219,12 +11054,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5544:3: (enumLiteral_1= 'false' )
+                    // InternalTestgeneratorDSL.g:4599:3: (enumLiteral_1= 'false' )
                     {
-                    // InternalTestgeneratorDSL.g:5544:3: (enumLiteral_1= 'false' )
-                    // InternalTestgeneratorDSL.g:5545:4: enumLiteral_1= 'false'
+                    // InternalTestgeneratorDSL.g:4599:3: (enumLiteral_1= 'false' )
+                    // InternalTestgeneratorDSL.g:4600:4: enumLiteral_1= 'false'
                     {
-                    enumLiteral_1=(Token)match(input,79,FOLLOW_2); 
+                    enumLiteral_1=(Token)match(input,77,FOLLOW_2); 
 
                     				current = grammarAccess.getBooleanAccess().getFALSEEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_1, grammarAccess.getBooleanAccess().getFALSEEnumLiteralDeclaration_1());
@@ -13258,7 +11093,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleStringCompareSymbol"
-    // InternalTestgeneratorDSL.g:5555:1: ruleStringCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) ;
+    // InternalTestgeneratorDSL.g:4610:1: ruleStringCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) ;
     public final Enumerator ruleStringCompareSymbol() throws RecognitionException {
         Enumerator current = null;
 
@@ -13269,33 +11104,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5561:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) )
-            // InternalTestgeneratorDSL.g:5562:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
+            // InternalTestgeneratorDSL.g:4616:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) )
+            // InternalTestgeneratorDSL.g:4617:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
             {
-            // InternalTestgeneratorDSL.g:5562:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
-            int alt111=2;
-            int LA111_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4617:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
+            int alt70=2;
+            int LA70_0 = input.LA(1);
 
-            if ( (LA111_0==68) ) {
-                alt111=1;
+            if ( (LA70_0==66) ) {
+                alt70=1;
             }
-            else if ( (LA111_0==69) ) {
-                alt111=2;
+            else if ( (LA70_0==67) ) {
+                alt70=2;
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 111, 0, input);
+                    new NoViableAltException("", 70, 0, input);
 
                 throw nvae;
             }
-            switch (alt111) {
+            switch (alt70) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5563:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4618:3: (enumLiteral_0= '==' )
                     {
-                    // InternalTestgeneratorDSL.g:5563:3: (enumLiteral_0= '==' )
-                    // InternalTestgeneratorDSL.g:5564:4: enumLiteral_0= '=='
+                    // InternalTestgeneratorDSL.g:4618:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4619:4: enumLiteral_0= '=='
                     {
-                    enumLiteral_0=(Token)match(input,68,FOLLOW_2); 
+                    enumLiteral_0=(Token)match(input,66,FOLLOW_2); 
 
                     				current = grammarAccess.getStringCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_0, grammarAccess.getStringCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0());
@@ -13307,12 +11142,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5571:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4626:3: (enumLiteral_1= '!=' )
                     {
-                    // InternalTestgeneratorDSL.g:5571:3: (enumLiteral_1= '!=' )
-                    // InternalTestgeneratorDSL.g:5572:4: enumLiteral_1= '!='
+                    // InternalTestgeneratorDSL.g:4626:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4627:4: enumLiteral_1= '!='
                     {
-                    enumLiteral_1=(Token)match(input,69,FOLLOW_2); 
+                    enumLiteral_1=(Token)match(input,67,FOLLOW_2); 
 
                     				current = grammarAccess.getStringCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_1, grammarAccess.getStringCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1());
@@ -13346,7 +11181,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleIntCompareSymbol"
-    // InternalTestgeneratorDSL.g:5582:1: ruleIntCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) ) ;
+    // InternalTestgeneratorDSL.g:4637:1: ruleIntCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) ) ;
     public final Enumerator ruleIntCompareSymbol() throws RecognitionException {
         Enumerator current = null;
 
@@ -13361,57 +11196,57 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5588:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) ) )
-            // InternalTestgeneratorDSL.g:5589:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) )
+            // InternalTestgeneratorDSL.g:4643:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) ) )
+            // InternalTestgeneratorDSL.g:4644:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) )
             {
-            // InternalTestgeneratorDSL.g:5589:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) )
-            int alt112=6;
+            // InternalTestgeneratorDSL.g:4644:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) | (enumLiteral_2= '<' ) | (enumLiteral_3= '>' ) | (enumLiteral_4= '<=' ) | (enumLiteral_5= '>=' ) )
+            int alt71=6;
             switch ( input.LA(1) ) {
-            case 68:
+            case 66:
                 {
-                alt112=1;
+                alt71=1;
                 }
                 break;
-            case 69:
+            case 67:
                 {
-                alt112=2;
+                alt71=2;
                 }
                 break;
-            case 80:
+            case 78:
                 {
-                alt112=3;
+                alt71=3;
                 }
                 break;
-            case 81:
+            case 79:
                 {
-                alt112=4;
+                alt71=4;
                 }
                 break;
-            case 82:
+            case 80:
                 {
-                alt112=5;
+                alt71=5;
                 }
                 break;
-            case 83:
+            case 81:
                 {
-                alt112=6;
+                alt71=6;
                 }
                 break;
             default:
                 NoViableAltException nvae =
-                    new NoViableAltException("", 112, 0, input);
+                    new NoViableAltException("", 71, 0, input);
 
                 throw nvae;
             }
 
-            switch (alt112) {
+            switch (alt71) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5590:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4645:3: (enumLiteral_0= '==' )
                     {
-                    // InternalTestgeneratorDSL.g:5590:3: (enumLiteral_0= '==' )
-                    // InternalTestgeneratorDSL.g:5591:4: enumLiteral_0= '=='
+                    // InternalTestgeneratorDSL.g:4645:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4646:4: enumLiteral_0= '=='
                     {
-                    enumLiteral_0=(Token)match(input,68,FOLLOW_2); 
+                    enumLiteral_0=(Token)match(input,66,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_0, grammarAccess.getIntCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0());
@@ -13423,12 +11258,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5598:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4653:3: (enumLiteral_1= '!=' )
                     {
-                    // InternalTestgeneratorDSL.g:5598:3: (enumLiteral_1= '!=' )
-                    // InternalTestgeneratorDSL.g:5599:4: enumLiteral_1= '!='
+                    // InternalTestgeneratorDSL.g:4653:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4654:4: enumLiteral_1= '!='
                     {
-                    enumLiteral_1=(Token)match(input,69,FOLLOW_2); 
+                    enumLiteral_1=(Token)match(input,67,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_1, grammarAccess.getIntCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1());
@@ -13440,12 +11275,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:5606:3: (enumLiteral_2= '<' )
+                    // InternalTestgeneratorDSL.g:4661:3: (enumLiteral_2= '<' )
                     {
-                    // InternalTestgeneratorDSL.g:5606:3: (enumLiteral_2= '<' )
-                    // InternalTestgeneratorDSL.g:5607:4: enumLiteral_2= '<'
+                    // InternalTestgeneratorDSL.g:4661:3: (enumLiteral_2= '<' )
+                    // InternalTestgeneratorDSL.g:4662:4: enumLiteral_2= '<'
                     {
-                    enumLiteral_2=(Token)match(input,80,FOLLOW_2); 
+                    enumLiteral_2=(Token)match(input,78,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getLOWEREnumLiteralDeclaration_2().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_2, grammarAccess.getIntCompareSymbolAccess().getLOWEREnumLiteralDeclaration_2());
@@ -13457,12 +11292,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 4 :
-                    // InternalTestgeneratorDSL.g:5614:3: (enumLiteral_3= '>' )
+                    // InternalTestgeneratorDSL.g:4669:3: (enumLiteral_3= '>' )
                     {
-                    // InternalTestgeneratorDSL.g:5614:3: (enumLiteral_3= '>' )
-                    // InternalTestgeneratorDSL.g:5615:4: enumLiteral_3= '>'
+                    // InternalTestgeneratorDSL.g:4669:3: (enumLiteral_3= '>' )
+                    // InternalTestgeneratorDSL.g:4670:4: enumLiteral_3= '>'
                     {
-                    enumLiteral_3=(Token)match(input,81,FOLLOW_2); 
+                    enumLiteral_3=(Token)match(input,79,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getGREATEREnumLiteralDeclaration_3().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_3, grammarAccess.getIntCompareSymbolAccess().getGREATEREnumLiteralDeclaration_3());
@@ -13474,12 +11309,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 5 :
-                    // InternalTestgeneratorDSL.g:5622:3: (enumLiteral_4= '<=' )
+                    // InternalTestgeneratorDSL.g:4677:3: (enumLiteral_4= '<=' )
                     {
-                    // InternalTestgeneratorDSL.g:5622:3: (enumLiteral_4= '<=' )
-                    // InternalTestgeneratorDSL.g:5623:4: enumLiteral_4= '<='
+                    // InternalTestgeneratorDSL.g:4677:3: (enumLiteral_4= '<=' )
+                    // InternalTestgeneratorDSL.g:4678:4: enumLiteral_4= '<='
                     {
-                    enumLiteral_4=(Token)match(input,82,FOLLOW_2); 
+                    enumLiteral_4=(Token)match(input,80,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getLOWER_EQUALSEnumLiteralDeclaration_4().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_4, grammarAccess.getIntCompareSymbolAccess().getLOWER_EQUALSEnumLiteralDeclaration_4());
@@ -13491,12 +11326,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 6 :
-                    // InternalTestgeneratorDSL.g:5630:3: (enumLiteral_5= '>=' )
+                    // InternalTestgeneratorDSL.g:4685:3: (enumLiteral_5= '>=' )
                     {
-                    // InternalTestgeneratorDSL.g:5630:3: (enumLiteral_5= '>=' )
-                    // InternalTestgeneratorDSL.g:5631:4: enumLiteral_5= '>='
+                    // InternalTestgeneratorDSL.g:4685:3: (enumLiteral_5= '>=' )
+                    // InternalTestgeneratorDSL.g:4686:4: enumLiteral_5= '>='
                     {
-                    enumLiteral_5=(Token)match(input,83,FOLLOW_2); 
+                    enumLiteral_5=(Token)match(input,81,FOLLOW_2); 
 
                     				current = grammarAccess.getIntCompareSymbolAccess().getGREATER_EQUALSEnumLiteralDeclaration_5().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_5, grammarAccess.getIntCompareSymbolAccess().getGREATER_EQUALSEnumLiteralDeclaration_5());
@@ -13530,7 +11365,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleBooleanCompareSymbol"
-    // InternalTestgeneratorDSL.g:5641:1: ruleBooleanCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) ;
+    // InternalTestgeneratorDSL.g:4696:1: ruleBooleanCompareSymbol returns [Enumerator current=null] : ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) ;
     public final Enumerator ruleBooleanCompareSymbol() throws RecognitionException {
         Enumerator current = null;
 
@@ -13541,33 +11376,33 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5647:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) )
-            // InternalTestgeneratorDSL.g:5648:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
+            // InternalTestgeneratorDSL.g:4702:2: ( ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) ) )
+            // InternalTestgeneratorDSL.g:4703:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
             {
-            // InternalTestgeneratorDSL.g:5648:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
-            int alt113=2;
-            int LA113_0 = input.LA(1);
+            // InternalTestgeneratorDSL.g:4703:2: ( (enumLiteral_0= '==' ) | (enumLiteral_1= '!=' ) )
+            int alt72=2;
+            int LA72_0 = input.LA(1);
 
-            if ( (LA113_0==68) ) {
-                alt113=1;
+            if ( (LA72_0==66) ) {
+                alt72=1;
             }
-            else if ( (LA113_0==69) ) {
-                alt113=2;
+            else if ( (LA72_0==67) ) {
+                alt72=2;
             }
             else {
                 NoViableAltException nvae =
-                    new NoViableAltException("", 113, 0, input);
+                    new NoViableAltException("", 72, 0, input);
 
                 throw nvae;
             }
-            switch (alt113) {
+            switch (alt72) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5649:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4704:3: (enumLiteral_0= '==' )
                     {
-                    // InternalTestgeneratorDSL.g:5649:3: (enumLiteral_0= '==' )
-                    // InternalTestgeneratorDSL.g:5650:4: enumLiteral_0= '=='
+                    // InternalTestgeneratorDSL.g:4704:3: (enumLiteral_0= '==' )
+                    // InternalTestgeneratorDSL.g:4705:4: enumLiteral_0= '=='
                     {
-                    enumLiteral_0=(Token)match(input,68,FOLLOW_2); 
+                    enumLiteral_0=(Token)match(input,66,FOLLOW_2); 
 
                     				current = grammarAccess.getBooleanCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_0, grammarAccess.getBooleanCompareSymbolAccess().getEQUALSEnumLiteralDeclaration_0());
@@ -13579,12 +11414,12 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5657:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4712:3: (enumLiteral_1= '!=' )
                     {
-                    // InternalTestgeneratorDSL.g:5657:3: (enumLiteral_1= '!=' )
-                    // InternalTestgeneratorDSL.g:5658:4: enumLiteral_1= '!='
+                    // InternalTestgeneratorDSL.g:4712:3: (enumLiteral_1= '!=' )
+                    // InternalTestgeneratorDSL.g:4713:4: enumLiteral_1= '!='
                     {
-                    enumLiteral_1=(Token)match(input,69,FOLLOW_2); 
+                    enumLiteral_1=(Token)match(input,67,FOLLOW_2); 
 
                     				current = grammarAccess.getBooleanCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
                     				newLeafNode(enumLiteral_1, grammarAccess.getBooleanCompareSymbolAccess().getNOT_EQUALSEnumLiteralDeclaration_1());
@@ -13618,57 +11453,63 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
 
     // $ANTLR start "ruleFlag"
-    // InternalTestgeneratorDSL.g:5668:1: ruleFlag returns [Enumerator current=null] : ( (enumLiteral_0= 'GREEN' ) | (enumLiteral_1= 'YELLOW' ) | (enumLiteral_2= 'RED' ) ) ;
+    // InternalTestgeneratorDSL.g:4723:1: ruleFlag returns [Enumerator current=null] : ( (enumLiteral_0= 'NONE' ) | (enumLiteral_1= 'GREEN' ) | (enumLiteral_2= 'YELLOW' ) | (enumLiteral_3= 'RED' ) ) ;
     public final Enumerator ruleFlag() throws RecognitionException {
         Enumerator current = null;
 
         Token enumLiteral_0=null;
         Token enumLiteral_1=null;
         Token enumLiteral_2=null;
+        Token enumLiteral_3=null;
 
 
         	enterRule();
 
         try {
-            // InternalTestgeneratorDSL.g:5674:2: ( ( (enumLiteral_0= 'GREEN' ) | (enumLiteral_1= 'YELLOW' ) | (enumLiteral_2= 'RED' ) ) )
-            // InternalTestgeneratorDSL.g:5675:2: ( (enumLiteral_0= 'GREEN' ) | (enumLiteral_1= 'YELLOW' ) | (enumLiteral_2= 'RED' ) )
+            // InternalTestgeneratorDSL.g:4729:2: ( ( (enumLiteral_0= 'NONE' ) | (enumLiteral_1= 'GREEN' ) | (enumLiteral_2= 'YELLOW' ) | (enumLiteral_3= 'RED' ) ) )
+            // InternalTestgeneratorDSL.g:4730:2: ( (enumLiteral_0= 'NONE' ) | (enumLiteral_1= 'GREEN' ) | (enumLiteral_2= 'YELLOW' ) | (enumLiteral_3= 'RED' ) )
             {
-            // InternalTestgeneratorDSL.g:5675:2: ( (enumLiteral_0= 'GREEN' ) | (enumLiteral_1= 'YELLOW' ) | (enumLiteral_2= 'RED' ) )
-            int alt114=3;
+            // InternalTestgeneratorDSL.g:4730:2: ( (enumLiteral_0= 'NONE' ) | (enumLiteral_1= 'GREEN' ) | (enumLiteral_2= 'YELLOW' ) | (enumLiteral_3= 'RED' ) )
+            int alt73=4;
             switch ( input.LA(1) ) {
-            case 84:
+            case 82:
                 {
-                alt114=1;
+                alt73=1;
                 }
                 break;
-            case 85:
+            case 83:
                 {
-                alt114=2;
+                alt73=2;
                 }
                 break;
-            case 86:
+            case 84:
+                {
+                alt73=3;
+                }
+                break;
+            case 85:
                 {
-                alt114=3;
+                alt73=4;
                 }
                 break;
             default:
                 NoViableAltException nvae =
-                    new NoViableAltException("", 114, 0, input);
+                    new NoViableAltException("", 73, 0, input);
 
                 throw nvae;
             }
 
-            switch (alt114) {
+            switch (alt73) {
                 case 1 :
-                    // InternalTestgeneratorDSL.g:5676:3: (enumLiteral_0= 'GREEN' )
+                    // InternalTestgeneratorDSL.g:4731:3: (enumLiteral_0= 'NONE' )
                     {
-                    // InternalTestgeneratorDSL.g:5676:3: (enumLiteral_0= 'GREEN' )
-                    // InternalTestgeneratorDSL.g:5677:4: enumLiteral_0= 'GREEN'
+                    // InternalTestgeneratorDSL.g:4731:3: (enumLiteral_0= 'NONE' )
+                    // InternalTestgeneratorDSL.g:4732:4: enumLiteral_0= 'NONE'
                     {
-                    enumLiteral_0=(Token)match(input,84,FOLLOW_2); 
+                    enumLiteral_0=(Token)match(input,82,FOLLOW_2); 
 
-                    				current = grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
-                    				newLeafNode(enumLiteral_0, grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_0());
+                    				current = grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0().getEnumLiteral().getInstance();
+                    				newLeafNode(enumLiteral_0, grammarAccess.getFlagAccess().getNONEEnumLiteralDeclaration_0());
                     			
 
                     }
@@ -13677,15 +11518,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 2 :
-                    // InternalTestgeneratorDSL.g:5684:3: (enumLiteral_1= 'YELLOW' )
+                    // InternalTestgeneratorDSL.g:4739:3: (enumLiteral_1= 'GREEN' )
                     {
-                    // InternalTestgeneratorDSL.g:5684:3: (enumLiteral_1= 'YELLOW' )
-                    // InternalTestgeneratorDSL.g:5685:4: enumLiteral_1= 'YELLOW'
+                    // InternalTestgeneratorDSL.g:4739:3: (enumLiteral_1= 'GREEN' )
+                    // InternalTestgeneratorDSL.g:4740:4: enumLiteral_1= 'GREEN'
                     {
-                    enumLiteral_1=(Token)match(input,85,FOLLOW_2); 
+                    enumLiteral_1=(Token)match(input,83,FOLLOW_2); 
 
-                    				current = grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
-                    				newLeafNode(enumLiteral_1, grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_1());
+                    				current = grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1().getEnumLiteral().getInstance();
+                    				newLeafNode(enumLiteral_1, grammarAccess.getFlagAccess().getGREENEnumLiteralDeclaration_1());
                     			
 
                     }
@@ -13694,15 +11535,32 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
                     }
                     break;
                 case 3 :
-                    // InternalTestgeneratorDSL.g:5692:3: (enumLiteral_2= 'RED' )
+                    // InternalTestgeneratorDSL.g:4747:3: (enumLiteral_2= 'YELLOW' )
+                    {
+                    // InternalTestgeneratorDSL.g:4747:3: (enumLiteral_2= 'YELLOW' )
+                    // InternalTestgeneratorDSL.g:4748:4: enumLiteral_2= 'YELLOW'
+                    {
+                    enumLiteral_2=(Token)match(input,84,FOLLOW_2); 
+
+                    				current = grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2().getEnumLiteral().getInstance();
+                    				newLeafNode(enumLiteral_2, grammarAccess.getFlagAccess().getYELLOWEnumLiteralDeclaration_2());
+                    			
+
+                    }
+
+
+                    }
+                    break;
+                case 4 :
+                    // InternalTestgeneratorDSL.g:4755:3: (enumLiteral_3= 'RED' )
                     {
-                    // InternalTestgeneratorDSL.g:5692:3: (enumLiteral_2= 'RED' )
-                    // InternalTestgeneratorDSL.g:5693:4: enumLiteral_2= 'RED'
+                    // InternalTestgeneratorDSL.g:4755:3: (enumLiteral_3= 'RED' )
+                    // InternalTestgeneratorDSL.g:4756:4: enumLiteral_3= 'RED'
                     {
-                    enumLiteral_2=(Token)match(input,86,FOLLOW_2); 
+                    enumLiteral_3=(Token)match(input,85,FOLLOW_2); 
 
-                    				current = grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2().getEnumLiteral().getInstance();
-                    				newLeafNode(enumLiteral_2, grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_2());
+                    				current = grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3().getEnumLiteral().getInstance();
+                    				newLeafNode(enumLiteral_3, grammarAccess.getFlagAccess().getREDEnumLiteralDeclaration_3());
                     			
 
                     }
@@ -13737,14 +11595,14 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
     protected DFA9 dfa9 = new DFA9(this);
     static final String dfa_1s = "\15\uffff";
     static final String dfa_2s = "\1\27\1\4\1\6\1\30\11\uffff";
-    static final String dfa_3s = "\1\27\1\4\1\6\1\52\11\uffff";
-    static final String dfa_4s = "\4\uffff\1\11\1\6\1\10\1\1\1\3\1\4\1\5\1\2\1\7";
+    static final String dfa_3s = "\1\27\1\4\1\6\1\50\11\uffff";
+    static final String dfa_4s = "\4\uffff\1\3\1\7\1\11\1\2\1\4\1\1\1\6\1\5\1\10";
     static final String dfa_5s = "\15\uffff}>";
     static final String[] dfa_6s = {
             "\1\1",
             "\1\2",
             "\1\3",
-            "\1\7\3\uffff\1\13\1\10\4\uffff\1\11\1\12\1\5\2\uffff\1\14\1\uffff\1\6\1\4",
+            "\1\11\1\uffff\1\7\1\4\2\uffff\1\10\1\13\1\12\4\uffff\1\5\1\uffff\1\14\1\6",
             "",
             "",
             "",
@@ -13784,7 +11642,7 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
 
     public static final BitSet FOLLOW_1 = new BitSet(new long[]{0x0000000000000000L});
     public static final BitSet FOLLOW_2 = new BitSet(new long[]{0x0000000000000002L});
-    public static final BitSet FOLLOW_3 = new BitSet(new long[]{0x4203B00000810002L,0x0000000000000140L});
+    public static final BitSet FOLLOW_3 = new BitSet(new long[]{0x1080EC0000810002L,0x0000000000000050L});
     public static final BitSet FOLLOW_4 = new BitSet(new long[]{0x0000000000000010L});
     public static final BitSet FOLLOW_5 = new BitSet(new long[]{0x0000000000020000L});
     public static final BitSet FOLLOW_6 = new BitSet(new long[]{0x0000000000040000L});
@@ -13801,15 +11659,15 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
     public static final BitSet FOLLOW_17 = new BitSet(new long[]{0x0000000000000400L});
     public static final BitSet FOLLOW_18 = new BitSet(new long[]{0x0000000001000000L});
     public static final BitSet FOLLOW_19 = new BitSet(new long[]{0x0000000002000000L});
-    public static final BitSet FOLLOW_20 = new BitSet(new long[]{0x0000000004000000L});
-    public static final BitSet FOLLOW_21 = new BitSet(new long[]{0x0000000000000210L});
+    public static final BitSet FOLLOW_20 = new BitSet(new long[]{0x0000000000000210L});
+    public static final BitSet FOLLOW_21 = new BitSet(new long[]{0x0000000004000000L});
     public static final BitSet FOLLOW_22 = new BitSet(new long[]{0x0000000008000000L});
-    public static final BitSet FOLLOW_23 = new BitSet(new long[]{0x0000000010000000L});
-    public static final BitSet FOLLOW_24 = new BitSet(new long[]{0x0000000020000000L});
-    public static final BitSet FOLLOW_25 = new BitSet(new long[]{0x0000000100020400L});
+    public static final BitSet FOLLOW_23 = new BitSet(new long[]{0x0000000010020400L});
+    public static final BitSet FOLLOW_24 = new BitSet(new long[]{0x0000000010000400L});
+    public static final BitSet FOLLOW_25 = new BitSet(new long[]{0x0000000020000000L});
     public static final BitSet FOLLOW_26 = new BitSet(new long[]{0x0000000040000000L});
     public static final BitSet FOLLOW_27 = new BitSet(new long[]{0x0000000080000000L});
-    public static final BitSet FOLLOW_28 = new BitSet(new long[]{0x0000000100000400L});
+    public static final BitSet FOLLOW_28 = new BitSet(new long[]{0x0000000100000000L});
     public static final BitSet FOLLOW_29 = new BitSet(new long[]{0x0000000200000000L});
     public static final BitSet FOLLOW_30 = new BitSet(new long[]{0x0000000400000000L});
     public static final BitSet FOLLOW_31 = new BitSet(new long[]{0x0000000800000000L});
@@ -13819,41 +11677,40 @@ public class InternalTestgeneratorDSLParser extends AbstractInternalAntlrParser
     public static final BitSet FOLLOW_35 = new BitSet(new long[]{0x0000008000000000L});
     public static final BitSet FOLLOW_36 = new BitSet(new long[]{0x0000010000000000L});
     public static final BitSet FOLLOW_37 = new BitSet(new long[]{0x0000020000000000L});
-    public static final BitSet FOLLOW_38 = new BitSet(new long[]{0x0000040000000000L});
-    public static final BitSet FOLLOW_39 = new BitSet(new long[]{0x0000080000000000L});
-    public static final BitSet FOLLOW_40 = new BitSet(new long[]{0x0000400000000000L});
+    public static final BitSet FOLLOW_38 = new BitSet(new long[]{0x0000000000000042L});
+    public static final BitSet FOLLOW_39 = new BitSet(new long[]{0x0000000000000000L,0x00000000003C0000L});
+    public static final BitSet FOLLOW_40 = new BitSet(new long[]{0x0000100000000000L});
     public static final BitSet FOLLOW_41 = new BitSet(new long[]{0x0000000000000A00L});
     public static final BitSet FOLLOW_42 = new BitSet(new long[]{0x0000000000000800L});
-    public static final BitSet FOLLOW_43 = new BitSet(new long[]{0x0000000000000200L,0x000000000000C000L});
-    public static final BitSet FOLLOW_44 = new BitSet(new long[]{0x0000000000000000L,0x000000000000C000L});
-    public static final BitSet FOLLOW_45 = new BitSet(new long[]{0x0004000000000000L});
-    public static final BitSet FOLLOW_46 = new BitSet(new long[]{0x0008000000000000L});
-    public static final BitSet FOLLOW_47 = new BitSet(new long[]{0x0010000000000000L});
-    public static final BitSet FOLLOW_48 = new BitSet(new long[]{0x0020000000000000L});
-    public static final BitSet FOLLOW_49 = new BitSet(new long[]{0x0040000000000000L});
-    public static final BitSet FOLLOW_50 = new BitSet(new long[]{0x0080000000000000L});
-    public static final BitSet FOLLOW_51 = new BitSet(new long[]{0x0100000000000000L});
-    public static final BitSet FOLLOW_52 = new BitSet(new long[]{0x0400000000000000L});
-    public static final BitSet FOLLOW_53 = new BitSet(new long[]{0x0800000000000000L});
-    public static final BitSet FOLLOW_54 = new BitSet(new long[]{0x0000000000000000L,0x0000000000700000L});
-    public static final BitSet FOLLOW_55 = new BitSet(new long[]{0x1000000000000000L});
-    public static final BitSet FOLLOW_56 = new BitSet(new long[]{0x2000000000000400L});
-    public static final BitSet FOLLOW_57 = new BitSet(new long[]{0x8000000000000000L});
-    public static final BitSet FOLLOW_58 = new BitSet(new long[]{0x0000000000020500L});
-    public static final BitSet FOLLOW_59 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000001L});
-    public static final BitSet FOLLOW_60 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000002L});
-    public static final BitSet FOLLOW_61 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000004L});
-    public static final BitSet FOLLOW_62 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000008L});
-    public static final BitSet FOLLOW_63 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000010L});
+    public static final BitSet FOLLOW_43 = new BitSet(new long[]{0x0000000000000200L,0x0000000000003000L});
+    public static final BitSet FOLLOW_44 = new BitSet(new long[]{0x0000000000000000L,0x0000000000003000L});
+    public static final BitSet FOLLOW_45 = new BitSet(new long[]{0x0001000000000000L});
+    public static final BitSet FOLLOW_46 = new BitSet(new long[]{0x0002000000000000L});
+    public static final BitSet FOLLOW_47 = new BitSet(new long[]{0x0004000000000000L});
+    public static final BitSet FOLLOW_48 = new BitSet(new long[]{0x0008000000000000L});
+    public static final BitSet FOLLOW_49 = new BitSet(new long[]{0x0010000000000000L});
+    public static final BitSet FOLLOW_50 = new BitSet(new long[]{0x0020000000000000L});
+    public static final BitSet FOLLOW_51 = new BitSet(new long[]{0x0040000000000000L});
+    public static final BitSet FOLLOW_52 = new BitSet(new long[]{0x0100000000000000L});
+    public static final BitSet FOLLOW_53 = new BitSet(new long[]{0x0200000000000000L});
+    public static final BitSet FOLLOW_54 = new BitSet(new long[]{0x0400000000000000L});
+    public static final BitSet FOLLOW_55 = new BitSet(new long[]{0x0800000000000400L});
+    public static final BitSet FOLLOW_56 = new BitSet(new long[]{0x2000000000000000L});
+    public static final BitSet FOLLOW_57 = new BitSet(new long[]{0x0000000000020500L});
+    public static final BitSet FOLLOW_58 = new BitSet(new long[]{0x4000000000000000L});
+    public static final BitSet FOLLOW_59 = new BitSet(new long[]{0x8000000000000000L});
+    public static final BitSet FOLLOW_60 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000001L});
+    public static final BitSet FOLLOW_61 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000002L});
+    public static final BitSet FOLLOW_62 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000004L});
+    public static final BitSet FOLLOW_63 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000008L});
     public static final BitSet FOLLOW_64 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000020L});
-    public static final BitSet FOLLOW_65 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000080L});
-    public static final BitSet FOLLOW_66 = new BitSet(new long[]{0x0000000000000500L});
-    public static final BitSet FOLLOW_67 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000200L});
-    public static final BitSet FOLLOW_68 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000400L});
-    public static final BitSet FOLLOW_69 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000800L});
-    public static final BitSet FOLLOW_70 = new BitSet(new long[]{0x0000000000000000L,0x0000000000001000L});
-    public static final BitSet FOLLOW_71 = new BitSet(new long[]{0x0000000000000000L,0x0000000000002000L});
-    public static final BitSet FOLLOW_72 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000030L});
-    public static final BitSet FOLLOW_73 = new BitSet(new long[]{0x0000000000000000L,0x00000000000F0030L});
+    public static final BitSet FOLLOW_65 = new BitSet(new long[]{0x0000000000000500L});
+    public static final BitSet FOLLOW_66 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000080L});
+    public static final BitSet FOLLOW_67 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000100L});
+    public static final BitSet FOLLOW_68 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000200L});
+    public static final BitSet FOLLOW_69 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000400L});
+    public static final BitSet FOLLOW_70 = new BitSet(new long[]{0x0000000000000000L,0x0000000000000800L});
+    public static final BitSet FOLLOW_71 = new BitSet(new long[]{0x0000000000000000L,0x000000000000000CL});
+    public static final BitSet FOLLOW_72 = new BitSet(new long[]{0x0000000000000000L,0x000000000003C00CL});
 
 }
\ No newline at end of file
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/services/TestgeneratorDSLGrammarAccess.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/services/TestgeneratorDSLGrammarAccess.java
index c60d0350a02efba7738c5a0ada691f6be8f26e4f..9c7b7aa571b9cec6fd2b991cca3101cc0e6661f9 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/services/TestgeneratorDSLGrammarAccess.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/services/TestgeneratorDSLGrammarAccess.java
@@ -350,43 +350,27 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final Keyword cStartEventKeyword_3 = (Keyword)cGroup.eContents().get(3);
 		private final Group cGroup_4 = (Group)cGroup.eContents().get(4);
 		private final Keyword cWithKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
-		private final Keyword cHardcodedKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
-		private final Keyword cInputsKeyword_4_2 = (Keyword)cGroup_4.eContents().get(2);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
-		private final RuleCall cLIST_OPENTerminalRuleCall_4_4 = (RuleCall)cGroup_4.eContents().get(4);
-		private final Group cGroup_4_5 = (Group)cGroup_4.eContents().get(5);
-		private final Assignment cHardcodedInputsAssignment_4_5_0 = (Assignment)cGroup_4_5.eContents().get(0);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0 = (RuleCall)cHardcodedInputsAssignment_4_5_0.eContents().get(0);
-		private final Group cGroup_4_5_1 = (Group)cGroup_4_5.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_4_5_1_0 = (RuleCall)cGroup_4_5_1.eContents().get(0);
-		private final Assignment cHardcodedInputsAssignment_4_5_1_1 = (Assignment)cGroup_4_5_1.eContents().get(1);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_4_5_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_6 = (RuleCall)cGroup_4.eContents().get(6);
-		private final Group cGroup_5 = (Group)cGroup.eContents().get(5);
-		private final Keyword cWithKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
-		private final Keyword cStartVariablesKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_5_2 = (RuleCall)cGroup_5.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_5_3 = (RuleCall)cGroup_5.eContents().get(3);
-		private final Group cGroup_5_4 = (Group)cGroup_5.eContents().get(4);
-		private final Assignment cStartVariablesAssignment_5_4_0 = (Assignment)cGroup_5_4.eContents().get(0);
-		private final RuleCall cStartVariablesVariableReferenceParserRuleCall_5_4_0_0 = (RuleCall)cStartVariablesAssignment_5_4_0.eContents().get(0);
-		private final Group cGroup_5_4_1 = (Group)cGroup_5_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_5_4_1_0 = (RuleCall)cGroup_5_4_1.eContents().get(0);
-		private final Assignment cStartVariablesAssignment_5_4_1_1 = (Assignment)cGroup_5_4_1.eContents().get(1);
-		private final RuleCall cStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0 = (RuleCall)cStartVariablesAssignment_5_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_5_5 = (RuleCall)cGroup_5.eContents().get(5);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_6 = (RuleCall)cGroup.eContents().get(6);
+		private final Keyword cInputVariablesKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_4_2 = (RuleCall)cGroup_4.eContents().get(2);
+		private final RuleCall cLIST_OPENTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
+		private final Group cGroup_4_4 = (Group)cGroup_4.eContents().get(4);
+		private final Assignment cInputVariablesAssignment_4_4_0 = (Assignment)cGroup_4_4.eContents().get(0);
+		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_4_4_0_0 = (RuleCall)cInputVariablesAssignment_4_4_0.eContents().get(0);
+		private final Group cGroup_4_4_1 = (Group)cGroup_4_4.eContents().get(1);
+		private final RuleCall cSEPARATORTerminalRuleCall_4_4_1_0 = (RuleCall)cGroup_4_4_1.eContents().get(0);
+		private final Assignment cInputVariablesAssignment_4_4_1_1 = (Assignment)cGroup_4_4_1.eContents().get(1);
+		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0 = (RuleCall)cInputVariablesAssignment_4_4_1_1.eContents().get(0);
+		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_5 = (RuleCall)cGroup_4.eContents().get(5);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_5 = (RuleCall)cGroup.eContents().get(5);
 		
 		//StartFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "StartEvent"
-		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//    ('with' 'startVariables' ASSOCIATION LIST_OPEN (startVariables+=VariableReference (SEPARATOR startVariables+=VariableReference)*)? LIST_CLOSED)?
+		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//"FlowElement" name=ID ASSOCIATION "StartEvent"
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//('with' 'startVariables' ASSOCIATION LIST_OPEN (startVariables+=VariableReference (SEPARATOR startVariables+=VariableReference)*)? LIST_CLOSED)?
+		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
 		
@@ -405,89 +389,47 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//"StartEvent"
 		public Keyword getStartEventKeyword_3() { return cStartEventKeyword_3; }
 		
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
+		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
 		public Group getGroup_4() { return cGroup_4; }
 		
 		//'with'
 		public Keyword getWithKeyword_4_0() { return cWithKeyword_4_0; }
 		
-		//'hardcoded'
-		public Keyword getHardcodedKeyword_4_1() { return cHardcodedKeyword_4_1; }
-		
-		//'inputs'
-		public Keyword getInputsKeyword_4_2() { return cInputsKeyword_4_2; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_4_3() { return cASSOCIATIONTerminalRuleCall_4_3; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_4_4() { return cLIST_OPENTerminalRuleCall_4_4; }
-		
-		//(hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)?
-		public Group getGroup_4_5() { return cGroup_4_5; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_0() { return cHardcodedInputsAssignment_4_5_0; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0; }
-		
-		//(SEPARATOR hardcodedInputs+=VariableDeclaration)*
-		public Group getGroup_4_5_1() { return cGroup_4_5_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_4_5_1_0() { return cSEPARATORTerminalRuleCall_4_5_1_0; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_1_1() { return cHardcodedInputsAssignment_4_5_1_1; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_6() { return cLIST_CLOSEDTerminalRuleCall_4_6; }
-		
-		//('with' 'startVariables' ASSOCIATION LIST_OPEN (startVariables+=VariableReference (SEPARATOR startVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_5() { return cGroup_5; }
-		
-		//'with'
-		public Keyword getWithKeyword_5_0() { return cWithKeyword_5_0; }
-		
-		//'startVariables'
-		public Keyword getStartVariablesKeyword_5_1() { return cStartVariablesKeyword_5_1; }
+		//'inputVariables'
+		public Keyword getInputVariablesKeyword_4_1() { return cInputVariablesKeyword_4_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_4_2() { return cASSOCIATIONTerminalRuleCall_4_2; }
 		
 		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_5_3() { return cLIST_OPENTerminalRuleCall_5_3; }
+		public RuleCall getLIST_OPENTerminalRuleCall_4_3() { return cLIST_OPENTerminalRuleCall_4_3; }
 		
-		//(startVariables+=VariableReference (SEPARATOR startVariables+=VariableReference)*)?
-		public Group getGroup_5_4() { return cGroup_5_4; }
+		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
+		public Group getGroup_4_4() { return cGroup_4_4; }
 		
-		//startVariables+=VariableReference
-		public Assignment getStartVariablesAssignment_5_4_0() { return cStartVariablesAssignment_5_4_0; }
+		//inputVariables+=VariableReference
+		public Assignment getInputVariablesAssignment_4_4_0() { return cInputVariablesAssignment_4_4_0; }
 		
 		//VariableReference
-		public RuleCall getStartVariablesVariableReferenceParserRuleCall_5_4_0_0() { return cStartVariablesVariableReferenceParserRuleCall_5_4_0_0; }
+		public RuleCall getInputVariablesVariableReferenceParserRuleCall_4_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_4_4_0_0; }
 		
-		//(SEPARATOR startVariables+=VariableReference)*
-		public Group getGroup_5_4_1() { return cGroup_5_4_1; }
+		//(SEPARATOR inputVariables+=VariableReference)*
+		public Group getGroup_4_4_1() { return cGroup_4_4_1; }
 		
 		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_5_4_1_0() { return cSEPARATORTerminalRuleCall_5_4_1_0; }
+		public RuleCall getSEPARATORTerminalRuleCall_4_4_1_0() { return cSEPARATORTerminalRuleCall_4_4_1_0; }
 		
-		//startVariables+=VariableReference
-		public Assignment getStartVariablesAssignment_5_4_1_1() { return cStartVariablesAssignment_5_4_1_1; }
+		//inputVariables+=VariableReference
+		public Assignment getInputVariablesAssignment_4_4_1_1() { return cInputVariablesAssignment_4_4_1_1; }
 		
 		//VariableReference
-		public RuleCall getStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0() { return cStartVariablesVariableReferenceParserRuleCall_5_4_1_1_0; }
+		public RuleCall getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0; }
 		
 		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_5_5() { return cLIST_CLOSEDTerminalRuleCall_5_5; }
+		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_5() { return cLIST_CLOSEDTerminalRuleCall_4_5; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_6() { return cDECLARATION_FINISHEDTerminalRuleCall_6; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_5() { return cDECLARATION_FINISHEDTerminalRuleCall_5; }
 	}
 	public class EndFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.EndFlowElement");
@@ -534,65 +476,34 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final Keyword cUserTaskKeyword_3 = (Keyword)cGroup.eContents().get(3);
 		private final Group cGroup_4 = (Group)cGroup.eContents().get(4);
 		private final Keyword cWithKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
-		private final Keyword cHardcodedKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
-		private final Keyword cInputsKeyword_4_2 = (Keyword)cGroup_4.eContents().get(2);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
-		private final RuleCall cLIST_OPENTerminalRuleCall_4_4 = (RuleCall)cGroup_4.eContents().get(4);
-		private final Group cGroup_4_5 = (Group)cGroup_4.eContents().get(5);
-		private final Assignment cHardcodedInputsAssignment_4_5_0 = (Assignment)cGroup_4_5.eContents().get(0);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0 = (RuleCall)cHardcodedInputsAssignment_4_5_0.eContents().get(0);
-		private final Group cGroup_4_5_1 = (Group)cGroup_4_5.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_4_5_1_0 = (RuleCall)cGroup_4_5_1.eContents().get(0);
-		private final Assignment cHardcodedInputsAssignment_4_5_1_1 = (Assignment)cGroup_4_5_1.eContents().get(1);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_4_5_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_6 = (RuleCall)cGroup_4.eContents().get(6);
+		private final Keyword cInputVariablesKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_4_2 = (RuleCall)cGroup_4.eContents().get(2);
+		private final RuleCall cLIST_OPENTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
+		private final Group cGroup_4_4 = (Group)cGroup_4.eContents().get(4);
+		private final Assignment cInputVariablesAssignment_4_4_0 = (Assignment)cGroup_4_4.eContents().get(0);
+		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_4_4_0_0 = (RuleCall)cInputVariablesAssignment_4_4_0.eContents().get(0);
+		private final Group cGroup_4_4_1 = (Group)cGroup_4_4.eContents().get(1);
+		private final RuleCall cSEPARATORTerminalRuleCall_4_4_1_0 = (RuleCall)cGroup_4_4_1.eContents().get(0);
+		private final Assignment cInputVariablesAssignment_4_4_1_1 = (Assignment)cGroup_4_4_1.eContents().get(1);
+		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0 = (RuleCall)cInputVariablesAssignment_4_4_1_1.eContents().get(0);
+		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_5 = (RuleCall)cGroup_4.eContents().get(5);
 		private final Group cGroup_5 = (Group)cGroup.eContents().get(5);
-		private final Keyword cWithKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
-		private final Keyword cInputVariablesKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
+		private final Keyword cAndKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
+		private final Keyword cLabelKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
 		private final RuleCall cASSOCIATIONTerminalRuleCall_5_2 = (RuleCall)cGroup_5.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_5_3 = (RuleCall)cGroup_5.eContents().get(3);
-		private final Group cGroup_5_4 = (Group)cGroup_5.eContents().get(4);
-		private final Assignment cInputVariablesAssignment_5_4_0 = (Assignment)cGroup_5_4.eContents().get(0);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_0_0 = (RuleCall)cInputVariablesAssignment_5_4_0.eContents().get(0);
-		private final Group cGroup_5_4_1 = (Group)cGroup_5_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_5_4_1_0 = (RuleCall)cGroup_5_4_1.eContents().get(0);
-		private final Assignment cInputVariablesAssignment_5_4_1_1 = (Assignment)cGroup_5_4_1.eContents().get(1);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0 = (RuleCall)cInputVariablesAssignment_5_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_5_5 = (RuleCall)cGroup_5.eContents().get(5);
-		private final Group cGroup_6 = (Group)cGroup.eContents().get(6);
-		private final Keyword cWithKeyword_6_0 = (Keyword)cGroup_6.eContents().get(0);
-		private final Keyword cOutputVariablesKeyword_6_1 = (Keyword)cGroup_6.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_6_2 = (RuleCall)cGroup_6.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_6_3 = (RuleCall)cGroup_6.eContents().get(3);
-		private final Group cGroup_6_4 = (Group)cGroup_6.eContents().get(4);
-		private final Assignment cOutputVariablesAssignment_6_4_0 = (Assignment)cGroup_6_4.eContents().get(0);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0 = (RuleCall)cOutputVariablesAssignment_6_4_0.eContents().get(0);
-		private final Group cGroup_6_4_1 = (Group)cGroup_6_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_6_4_1_0 = (RuleCall)cGroup_6_4_1.eContents().get(0);
-		private final Assignment cOutputVariablesAssignment_6_4_1_1 = (Assignment)cGroup_6_4_1.eContents().get(1);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0 = (RuleCall)cOutputVariablesAssignment_6_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_6_5 = (RuleCall)cGroup_6.eContents().get(5);
-		private final Group cGroup_7 = (Group)cGroup.eContents().get(7);
-		private final Keyword cAndKeyword_7_0 = (Keyword)cGroup_7.eContents().get(0);
-		private final Keyword cLabelKeyword_7_1 = (Keyword)cGroup_7.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_7_2 = (RuleCall)cGroup_7.eContents().get(2);
-		private final Assignment cLabelAssignment_7_3 = (Assignment)cGroup_7.eContents().get(3);
-		private final RuleCall cLabelSTRINGTerminalRuleCall_7_3_0 = (RuleCall)cLabelAssignment_7_3.eContents().get(0);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_8 = (RuleCall)cGroup.eContents().get(8);
+		private final Assignment cLabelAssignment_5_3 = (Assignment)cGroup_5.eContents().get(3);
+		private final RuleCall cLabelSTRINGTerminalRuleCall_5_3_0 = (RuleCall)cLabelAssignment_5_3.eContents().get(0);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_6 = (RuleCall)cGroup.eContents().get(6);
 		
 		//UserTaskFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "UserTask"
-		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
 		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    ('and' 'label' ASSOCIATION label=STRING)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//"FlowElement" name=ID ASSOCIATION "UserTask"
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
 		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//('and' 'label' ASSOCIATION label=STRING)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -612,146 +523,65 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//"UserTask"
 		public Keyword getUserTaskKeyword_3() { return cUserTaskKeyword_3; }
 		
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
+		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
 		public Group getGroup_4() { return cGroup_4; }
 		
 		//'with'
 		public Keyword getWithKeyword_4_0() { return cWithKeyword_4_0; }
 		
-		//'hardcoded'
-		public Keyword getHardcodedKeyword_4_1() { return cHardcodedKeyword_4_1; }
-		
-		//'inputs'
-		public Keyword getInputsKeyword_4_2() { return cInputsKeyword_4_2; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_4_3() { return cASSOCIATIONTerminalRuleCall_4_3; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_4_4() { return cLIST_OPENTerminalRuleCall_4_4; }
-		
-		//(hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)?
-		public Group getGroup_4_5() { return cGroup_4_5; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_0() { return cHardcodedInputsAssignment_4_5_0; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0; }
-		
-		//(SEPARATOR hardcodedInputs+=VariableDeclaration)*
-		public Group getGroup_4_5_1() { return cGroup_4_5_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_4_5_1_0() { return cSEPARATORTerminalRuleCall_4_5_1_0; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_1_1() { return cHardcodedInputsAssignment_4_5_1_1; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_6() { return cLIST_CLOSEDTerminalRuleCall_4_6; }
-		
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_5() { return cGroup_5; }
-		
-		//'with'
-		public Keyword getWithKeyword_5_0() { return cWithKeyword_5_0; }
-		
 		//'inputVariables'
-		public Keyword getInputVariablesKeyword_5_1() { return cInputVariablesKeyword_5_1; }
+		public Keyword getInputVariablesKeyword_4_1() { return cInputVariablesKeyword_4_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_4_2() { return cASSOCIATIONTerminalRuleCall_4_2; }
 		
 		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_5_3() { return cLIST_OPENTerminalRuleCall_5_3; }
+		public RuleCall getLIST_OPENTerminalRuleCall_4_3() { return cLIST_OPENTerminalRuleCall_4_3; }
 		
 		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
-		public Group getGroup_5_4() { return cGroup_5_4; }
+		public Group getGroup_4_4() { return cGroup_4_4; }
 		
 		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_0() { return cInputVariablesAssignment_5_4_0; }
+		public Assignment getInputVariablesAssignment_4_4_0() { return cInputVariablesAssignment_4_4_0; }
 		
 		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_0_0; }
+		public RuleCall getInputVariablesVariableReferenceParserRuleCall_4_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_4_4_0_0; }
 		
 		//(SEPARATOR inputVariables+=VariableReference)*
-		public Group getGroup_5_4_1() { return cGroup_5_4_1; }
+		public Group getGroup_4_4_1() { return cGroup_4_4_1; }
 		
 		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_5_4_1_0() { return cSEPARATORTerminalRuleCall_5_4_1_0; }
+		public RuleCall getSEPARATORTerminalRuleCall_4_4_1_0() { return cSEPARATORTerminalRuleCall_4_4_1_0; }
 		
 		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_1_1() { return cInputVariablesAssignment_5_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_5_5() { return cLIST_CLOSEDTerminalRuleCall_5_5; }
-		
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_6() { return cGroup_6; }
-		
-		//'with'
-		public Keyword getWithKeyword_6_0() { return cWithKeyword_6_0; }
-		
-		//'outputVariables'
-		public Keyword getOutputVariablesKeyword_6_1() { return cOutputVariablesKeyword_6_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_6_2() { return cASSOCIATIONTerminalRuleCall_6_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_6_3() { return cLIST_OPENTerminalRuleCall_6_3; }
-		
-		//(outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)?
-		public Group getGroup_6_4() { return cGroup_6_4; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_0() { return cOutputVariablesAssignment_6_4_0; }
+		public Assignment getInputVariablesAssignment_4_4_1_1() { return cInputVariablesAssignment_4_4_1_1; }
 		
 		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0; }
-		
-		//(SEPARATOR outputVariables+=VariableReference)*
-		public Group getGroup_6_4_1() { return cGroup_6_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_6_4_1_0() { return cSEPARATORTerminalRuleCall_6_4_1_0; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_1_1() { return cOutputVariablesAssignment_6_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0; }
+		public RuleCall getInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_4_4_1_1_0; }
 		
 		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_6_5() { return cLIST_CLOSEDTerminalRuleCall_6_5; }
+		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_5() { return cLIST_CLOSEDTerminalRuleCall_4_5; }
 		
 		//('and' 'label' ASSOCIATION label=STRING)?
-		public Group getGroup_7() { return cGroup_7; }
+		public Group getGroup_5() { return cGroup_5; }
 		
 		//'and'
-		public Keyword getAndKeyword_7_0() { return cAndKeyword_7_0; }
+		public Keyword getAndKeyword_5_0() { return cAndKeyword_5_0; }
 		
 		//'label'
-		public Keyword getLabelKeyword_7_1() { return cLabelKeyword_7_1; }
+		public Keyword getLabelKeyword_5_1() { return cLabelKeyword_5_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_7_2() { return cASSOCIATIONTerminalRuleCall_7_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
 		
 		//label=STRING
-		public Assignment getLabelAssignment_7_3() { return cLabelAssignment_7_3; }
+		public Assignment getLabelAssignment_5_3() { return cLabelAssignment_5_3; }
 		
 		//STRING
-		public RuleCall getLabelSTRINGTerminalRuleCall_7_3_0() { return cLabelSTRINGTerminalRuleCall_7_3_0; }
+		public RuleCall getLabelSTRINGTerminalRuleCall_5_3_0() { return cLabelSTRINGTerminalRuleCall_5_3_0; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_8() { return cDECLARATION_FINISHEDTerminalRuleCall_8; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_6() { return cDECLARATION_FINISHEDTerminalRuleCall_6; }
 	}
 	public class ManualTaskFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.ManualTaskFlowElement");
@@ -762,66 +592,20 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final RuleCall cASSOCIATIONTerminalRuleCall_2 = (RuleCall)cGroup.eContents().get(2);
 		private final Keyword cManualTaskKeyword_3 = (Keyword)cGroup.eContents().get(3);
 		private final Group cGroup_4 = (Group)cGroup.eContents().get(4);
-		private final Keyword cWithKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
-		private final Keyword cHardcodedKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
-		private final Keyword cInputsKeyword_4_2 = (Keyword)cGroup_4.eContents().get(2);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
-		private final RuleCall cLIST_OPENTerminalRuleCall_4_4 = (RuleCall)cGroup_4.eContents().get(4);
-		private final Group cGroup_4_5 = (Group)cGroup_4.eContents().get(5);
-		private final Assignment cHardcodedInputsAssignment_4_5_0 = (Assignment)cGroup_4_5.eContents().get(0);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0 = (RuleCall)cHardcodedInputsAssignment_4_5_0.eContents().get(0);
-		private final Group cGroup_4_5_1 = (Group)cGroup_4_5.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_4_5_1_0 = (RuleCall)cGroup_4_5_1.eContents().get(0);
-		private final Assignment cHardcodedInputsAssignment_4_5_1_1 = (Assignment)cGroup_4_5_1.eContents().get(1);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_4_5_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_6 = (RuleCall)cGroup_4.eContents().get(6);
-		private final Group cGroup_5 = (Group)cGroup.eContents().get(5);
-		private final Keyword cWithKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
-		private final Keyword cInputVariablesKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_5_2 = (RuleCall)cGroup_5.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_5_3 = (RuleCall)cGroup_5.eContents().get(3);
-		private final Group cGroup_5_4 = (Group)cGroup_5.eContents().get(4);
-		private final Assignment cInputVariablesAssignment_5_4_0 = (Assignment)cGroup_5_4.eContents().get(0);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_0_0 = (RuleCall)cInputVariablesAssignment_5_4_0.eContents().get(0);
-		private final Group cGroup_5_4_1 = (Group)cGroup_5_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_5_4_1_0 = (RuleCall)cGroup_5_4_1.eContents().get(0);
-		private final Assignment cInputVariablesAssignment_5_4_1_1 = (Assignment)cGroup_5_4_1.eContents().get(1);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0 = (RuleCall)cInputVariablesAssignment_5_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_5_5 = (RuleCall)cGroup_5.eContents().get(5);
-		private final Group cGroup_6 = (Group)cGroup.eContents().get(6);
-		private final Keyword cWithKeyword_6_0 = (Keyword)cGroup_6.eContents().get(0);
-		private final Keyword cOutputVariablesKeyword_6_1 = (Keyword)cGroup_6.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_6_2 = (RuleCall)cGroup_6.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_6_3 = (RuleCall)cGroup_6.eContents().get(3);
-		private final Group cGroup_6_4 = (Group)cGroup_6.eContents().get(4);
-		private final Assignment cOutputVariablesAssignment_6_4_0 = (Assignment)cGroup_6_4.eContents().get(0);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0 = (RuleCall)cOutputVariablesAssignment_6_4_0.eContents().get(0);
-		private final Group cGroup_6_4_1 = (Group)cGroup_6_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_6_4_1_0 = (RuleCall)cGroup_6_4_1.eContents().get(0);
-		private final Assignment cOutputVariablesAssignment_6_4_1_1 = (Assignment)cGroup_6_4_1.eContents().get(1);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0 = (RuleCall)cOutputVariablesAssignment_6_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_6_5 = (RuleCall)cGroup_6.eContents().get(5);
-		private final Group cGroup_7 = (Group)cGroup.eContents().get(7);
-		private final Keyword cAndKeyword_7_0 = (Keyword)cGroup_7.eContents().get(0);
-		private final Keyword cLabelKeyword_7_1 = (Keyword)cGroup_7.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_7_2 = (RuleCall)cGroup_7.eContents().get(2);
-		private final Assignment cLabelAssignment_7_3 = (Assignment)cGroup_7.eContents().get(3);
-		private final RuleCall cLabelSTRINGTerminalRuleCall_7_3_0 = (RuleCall)cLabelAssignment_7_3.eContents().get(0);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_8 = (RuleCall)cGroup.eContents().get(8);
+		private final Keyword cAndKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
+		private final Keyword cLabelKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_4_2 = (RuleCall)cGroup_4.eContents().get(2);
+		private final Assignment cLabelAssignment_4_3 = (Assignment)cGroup_4.eContents().get(3);
+		private final RuleCall cLabelSTRINGTerminalRuleCall_4_3_0 = (RuleCall)cLabelAssignment_4_3.eContents().get(0);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_5 = (RuleCall)cGroup.eContents().get(5);
 		
 		//ManualTaskFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "ManualTask"
-		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    ('and' 'label' ASSOCIATION label=STRING)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//"FlowElement" name=ID ASSOCIATION "ManualTask"
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//('and' 'label' ASSOCIATION label=STRING)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -841,146 +625,26 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//"ManualTask"
 		public Keyword getManualTaskKeyword_3() { return cManualTaskKeyword_3; }
 		
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		public Group getGroup_4() { return cGroup_4; }
-		
-		//'with'
-		public Keyword getWithKeyword_4_0() { return cWithKeyword_4_0; }
-		
-		//'hardcoded'
-		public Keyword getHardcodedKeyword_4_1() { return cHardcodedKeyword_4_1; }
-		
-		//'inputs'
-		public Keyword getInputsKeyword_4_2() { return cInputsKeyword_4_2; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_4_3() { return cASSOCIATIONTerminalRuleCall_4_3; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_4_4() { return cLIST_OPENTerminalRuleCall_4_4; }
-		
-		//(hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)?
-		public Group getGroup_4_5() { return cGroup_4_5; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_0() { return cHardcodedInputsAssignment_4_5_0; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0; }
-		
-		//(SEPARATOR hardcodedInputs+=VariableDeclaration)*
-		public Group getGroup_4_5_1() { return cGroup_4_5_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_4_5_1_0() { return cSEPARATORTerminalRuleCall_4_5_1_0; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_1_1() { return cHardcodedInputsAssignment_4_5_1_1; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_6() { return cLIST_CLOSEDTerminalRuleCall_4_6; }
-		
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_5() { return cGroup_5; }
-		
-		//'with'
-		public Keyword getWithKeyword_5_0() { return cWithKeyword_5_0; }
-		
-		//'inputVariables'
-		public Keyword getInputVariablesKeyword_5_1() { return cInputVariablesKeyword_5_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_5_3() { return cLIST_OPENTerminalRuleCall_5_3; }
-		
-		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
-		public Group getGroup_5_4() { return cGroup_5_4; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_0() { return cInputVariablesAssignment_5_4_0; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_0_0; }
-		
-		//(SEPARATOR inputVariables+=VariableReference)*
-		public Group getGroup_5_4_1() { return cGroup_5_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_5_4_1_0() { return cSEPARATORTerminalRuleCall_5_4_1_0; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_1_1() { return cInputVariablesAssignment_5_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_5_5() { return cLIST_CLOSEDTerminalRuleCall_5_5; }
-		
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_6() { return cGroup_6; }
-		
-		//'with'
-		public Keyword getWithKeyword_6_0() { return cWithKeyword_6_0; }
-		
-		//'outputVariables'
-		public Keyword getOutputVariablesKeyword_6_1() { return cOutputVariablesKeyword_6_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_6_2() { return cASSOCIATIONTerminalRuleCall_6_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_6_3() { return cLIST_OPENTerminalRuleCall_6_3; }
-		
-		//(outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)?
-		public Group getGroup_6_4() { return cGroup_6_4; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_0() { return cOutputVariablesAssignment_6_4_0; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0; }
-		
-		//(SEPARATOR outputVariables+=VariableReference)*
-		public Group getGroup_6_4_1() { return cGroup_6_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_6_4_1_0() { return cSEPARATORTerminalRuleCall_6_4_1_0; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_1_1() { return cOutputVariablesAssignment_6_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_6_5() { return cLIST_CLOSEDTerminalRuleCall_6_5; }
-		
 		//('and' 'label' ASSOCIATION label=STRING)?
-		public Group getGroup_7() { return cGroup_7; }
+		public Group getGroup_4() { return cGroup_4; }
 		
 		//'and'
-		public Keyword getAndKeyword_7_0() { return cAndKeyword_7_0; }
+		public Keyword getAndKeyword_4_0() { return cAndKeyword_4_0; }
 		
 		//'label'
-		public Keyword getLabelKeyword_7_1() { return cLabelKeyword_7_1; }
+		public Keyword getLabelKeyword_4_1() { return cLabelKeyword_4_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_7_2() { return cASSOCIATIONTerminalRuleCall_7_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_4_2() { return cASSOCIATIONTerminalRuleCall_4_2; }
 		
 		//label=STRING
-		public Assignment getLabelAssignment_7_3() { return cLabelAssignment_7_3; }
+		public Assignment getLabelAssignment_4_3() { return cLabelAssignment_4_3; }
 		
 		//STRING
-		public RuleCall getLabelSTRINGTerminalRuleCall_7_3_0() { return cLabelSTRINGTerminalRuleCall_7_3_0; }
+		public RuleCall getLabelSTRINGTerminalRuleCall_4_3_0() { return cLabelSTRINGTerminalRuleCall_4_3_0; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_8() { return cDECLARATION_FINISHEDTerminalRuleCall_8; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_5() { return cDECLARATION_FINISHEDTerminalRuleCall_5; }
 	}
 	public class ScriptTaskFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.ScriptTaskFlowElement");
@@ -991,66 +655,20 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final RuleCall cASSOCIATIONTerminalRuleCall_2 = (RuleCall)cGroup.eContents().get(2);
 		private final Keyword cScriptTaskKeyword_3 = (Keyword)cGroup.eContents().get(3);
 		private final Group cGroup_4 = (Group)cGroup.eContents().get(4);
-		private final Keyword cWithKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
-		private final Keyword cHardcodedKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
-		private final Keyword cInputsKeyword_4_2 = (Keyword)cGroup_4.eContents().get(2);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_4_3 = (RuleCall)cGroup_4.eContents().get(3);
-		private final RuleCall cLIST_OPENTerminalRuleCall_4_4 = (RuleCall)cGroup_4.eContents().get(4);
-		private final Group cGroup_4_5 = (Group)cGroup_4.eContents().get(5);
-		private final Assignment cHardcodedInputsAssignment_4_5_0 = (Assignment)cGroup_4_5.eContents().get(0);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0 = (RuleCall)cHardcodedInputsAssignment_4_5_0.eContents().get(0);
-		private final Group cGroup_4_5_1 = (Group)cGroup_4_5.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_4_5_1_0 = (RuleCall)cGroup_4_5_1.eContents().get(0);
-		private final Assignment cHardcodedInputsAssignment_4_5_1_1 = (Assignment)cGroup_4_5_1.eContents().get(1);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_4_5_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_4_6 = (RuleCall)cGroup_4.eContents().get(6);
-		private final Group cGroup_5 = (Group)cGroup.eContents().get(5);
-		private final Keyword cWithKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
-		private final Keyword cInputVariablesKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_5_2 = (RuleCall)cGroup_5.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_5_3 = (RuleCall)cGroup_5.eContents().get(3);
-		private final Group cGroup_5_4 = (Group)cGroup_5.eContents().get(4);
-		private final Assignment cInputVariablesAssignment_5_4_0 = (Assignment)cGroup_5_4.eContents().get(0);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_0_0 = (RuleCall)cInputVariablesAssignment_5_4_0.eContents().get(0);
-		private final Group cGroup_5_4_1 = (Group)cGroup_5_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_5_4_1_0 = (RuleCall)cGroup_5_4_1.eContents().get(0);
-		private final Assignment cInputVariablesAssignment_5_4_1_1 = (Assignment)cGroup_5_4_1.eContents().get(1);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0 = (RuleCall)cInputVariablesAssignment_5_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_5_5 = (RuleCall)cGroup_5.eContents().get(5);
-		private final Group cGroup_6 = (Group)cGroup.eContents().get(6);
-		private final Keyword cWithKeyword_6_0 = (Keyword)cGroup_6.eContents().get(0);
-		private final Keyword cOutputVariablesKeyword_6_1 = (Keyword)cGroup_6.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_6_2 = (RuleCall)cGroup_6.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_6_3 = (RuleCall)cGroup_6.eContents().get(3);
-		private final Group cGroup_6_4 = (Group)cGroup_6.eContents().get(4);
-		private final Assignment cOutputVariablesAssignment_6_4_0 = (Assignment)cGroup_6_4.eContents().get(0);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0 = (RuleCall)cOutputVariablesAssignment_6_4_0.eContents().get(0);
-		private final Group cGroup_6_4_1 = (Group)cGroup_6_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_6_4_1_0 = (RuleCall)cGroup_6_4_1.eContents().get(0);
-		private final Assignment cOutputVariablesAssignment_6_4_1_1 = (Assignment)cGroup_6_4_1.eContents().get(1);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0 = (RuleCall)cOutputVariablesAssignment_6_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_6_5 = (RuleCall)cGroup_6.eContents().get(5);
-		private final Group cGroup_7 = (Group)cGroup.eContents().get(7);
-		private final Keyword cAndKeyword_7_0 = (Keyword)cGroup_7.eContents().get(0);
-		private final Keyword cLabelKeyword_7_1 = (Keyword)cGroup_7.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_7_2 = (RuleCall)cGroup_7.eContents().get(2);
-		private final Assignment cLabelAssignment_7_3 = (Assignment)cGroup_7.eContents().get(3);
-		private final RuleCall cLabelSTRINGTerminalRuleCall_7_3_0 = (RuleCall)cLabelAssignment_7_3.eContents().get(0);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_8 = (RuleCall)cGroup.eContents().get(8);
+		private final Keyword cAndKeyword_4_0 = (Keyword)cGroup_4.eContents().get(0);
+		private final Keyword cLabelKeyword_4_1 = (Keyword)cGroup_4.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_4_2 = (RuleCall)cGroup_4.eContents().get(2);
+		private final Assignment cLabelAssignment_4_3 = (Assignment)cGroup_4.eContents().get(3);
+		private final RuleCall cLabelSTRINGTerminalRuleCall_4_3_0 = (RuleCall)cLabelAssignment_4_3.eContents().get(0);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_5 = (RuleCall)cGroup.eContents().get(5);
 		
 		//ScriptTaskFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "ScriptTask"
-		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    ('and' 'label' ASSOCIATION label=STRING)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//"FlowElement" name=ID ASSOCIATION "ScriptTask"
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//('and' 'label' ASSOCIATION label=STRING)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -1070,146 +688,26 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//"ScriptTask"
 		public Keyword getScriptTaskKeyword_3() { return cScriptTaskKeyword_3; }
 		
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		public Group getGroup_4() { return cGroup_4; }
-		
-		//'with'
-		public Keyword getWithKeyword_4_0() { return cWithKeyword_4_0; }
-		
-		//'hardcoded'
-		public Keyword getHardcodedKeyword_4_1() { return cHardcodedKeyword_4_1; }
-		
-		//'inputs'
-		public Keyword getInputsKeyword_4_2() { return cInputsKeyword_4_2; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_4_3() { return cASSOCIATIONTerminalRuleCall_4_3; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_4_4() { return cLIST_OPENTerminalRuleCall_4_4; }
-		
-		//(hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)?
-		public Group getGroup_4_5() { return cGroup_4_5; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_0() { return cHardcodedInputsAssignment_4_5_0; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_0_0; }
-		
-		//(SEPARATOR hardcodedInputs+=VariableDeclaration)*
-		public Group getGroup_4_5_1() { return cGroup_4_5_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_4_5_1_0() { return cSEPARATORTerminalRuleCall_4_5_1_0; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_4_5_1_1() { return cHardcodedInputsAssignment_4_5_1_1; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_4_5_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_4_6() { return cLIST_CLOSEDTerminalRuleCall_4_6; }
-		
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_5() { return cGroup_5; }
-		
-		//'with'
-		public Keyword getWithKeyword_5_0() { return cWithKeyword_5_0; }
-		
-		//'inputVariables'
-		public Keyword getInputVariablesKeyword_5_1() { return cInputVariablesKeyword_5_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_5_3() { return cLIST_OPENTerminalRuleCall_5_3; }
-		
-		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
-		public Group getGroup_5_4() { return cGroup_5_4; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_0() { return cInputVariablesAssignment_5_4_0; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_0_0; }
-		
-		//(SEPARATOR inputVariables+=VariableReference)*
-		public Group getGroup_5_4_1() { return cGroup_5_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_5_4_1_0() { return cSEPARATORTerminalRuleCall_5_4_1_0; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_5_4_1_1() { return cInputVariablesAssignment_5_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_5_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_5_5() { return cLIST_CLOSEDTerminalRuleCall_5_5; }
-		
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_6() { return cGroup_6; }
-		
-		//'with'
-		public Keyword getWithKeyword_6_0() { return cWithKeyword_6_0; }
-		
-		//'outputVariables'
-		public Keyword getOutputVariablesKeyword_6_1() { return cOutputVariablesKeyword_6_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_6_2() { return cASSOCIATIONTerminalRuleCall_6_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_6_3() { return cLIST_OPENTerminalRuleCall_6_3; }
-		
-		//(outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)?
-		public Group getGroup_6_4() { return cGroup_6_4; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_0() { return cOutputVariablesAssignment_6_4_0; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_0_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_0_0; }
-		
-		//(SEPARATOR outputVariables+=VariableReference)*
-		public Group getGroup_6_4_1() { return cGroup_6_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_6_4_1_0() { return cSEPARATORTerminalRuleCall_6_4_1_0; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_6_4_1_1() { return cOutputVariablesAssignment_6_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0() { return cOutputVariablesVariableReferenceParserRuleCall_6_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_6_5() { return cLIST_CLOSEDTerminalRuleCall_6_5; }
-		
 		//('and' 'label' ASSOCIATION label=STRING)?
-		public Group getGroup_7() { return cGroup_7; }
+		public Group getGroup_4() { return cGroup_4; }
 		
 		//'and'
-		public Keyword getAndKeyword_7_0() { return cAndKeyword_7_0; }
+		public Keyword getAndKeyword_4_0() { return cAndKeyword_4_0; }
 		
 		//'label'
-		public Keyword getLabelKeyword_7_1() { return cLabelKeyword_7_1; }
+		public Keyword getLabelKeyword_4_1() { return cLabelKeyword_4_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_7_2() { return cASSOCIATIONTerminalRuleCall_7_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_4_2() { return cASSOCIATIONTerminalRuleCall_4_2; }
 		
 		//label=STRING
-		public Assignment getLabelAssignment_7_3() { return cLabelAssignment_7_3; }
+		public Assignment getLabelAssignment_4_3() { return cLabelAssignment_4_3; }
 		
 		//STRING
-		public RuleCall getLabelSTRINGTerminalRuleCall_7_3_0() { return cLabelSTRINGTerminalRuleCall_7_3_0; }
+		public RuleCall getLabelSTRINGTerminalRuleCall_4_3_0() { return cLabelSTRINGTerminalRuleCall_4_3_0; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_8() { return cDECLARATION_FINISHEDTerminalRuleCall_8; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_5() { return cDECLARATION_FINISHEDTerminalRuleCall_5; }
 	}
 	public class ServiceTaskFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.ServiceTaskFlowElement");
@@ -1343,45 +841,17 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_8_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_8_5_1_1.eContents().get(0);
 		private final RuleCall cLIST_CLOSEDTerminalRuleCall_8_6 = (RuleCall)cGroup_8.eContents().get(6);
 		private final Group cGroup_9 = (Group)cGroup.eContents().get(9);
-		private final Keyword cWithKeyword_9_0 = (Keyword)cGroup_9.eContents().get(0);
-		private final Keyword cInputVariablesKeyword_9_1 = (Keyword)cGroup_9.eContents().get(1);
+		private final Keyword cAndKeyword_9_0 = (Keyword)cGroup_9.eContents().get(0);
+		private final Keyword cLabelKeyword_9_1 = (Keyword)cGroup_9.eContents().get(1);
 		private final RuleCall cASSOCIATIONTerminalRuleCall_9_2 = (RuleCall)cGroup_9.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_9_3 = (RuleCall)cGroup_9.eContents().get(3);
-		private final Group cGroup_9_4 = (Group)cGroup_9.eContents().get(4);
-		private final Assignment cInputVariablesAssignment_9_4_0 = (Assignment)cGroup_9_4.eContents().get(0);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_9_4_0_0 = (RuleCall)cInputVariablesAssignment_9_4_0.eContents().get(0);
-		private final Group cGroup_9_4_1 = (Group)cGroup_9_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_9_4_1_0 = (RuleCall)cGroup_9_4_1.eContents().get(0);
-		private final Assignment cInputVariablesAssignment_9_4_1_1 = (Assignment)cGroup_9_4_1.eContents().get(1);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0 = (RuleCall)cInputVariablesAssignment_9_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_9_5 = (RuleCall)cGroup_9.eContents().get(5);
-		private final Group cGroup_10 = (Group)cGroup.eContents().get(10);
-		private final Keyword cWithKeyword_10_0 = (Keyword)cGroup_10.eContents().get(0);
-		private final Keyword cOutputVariablesKeyword_10_1 = (Keyword)cGroup_10.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_10_2 = (RuleCall)cGroup_10.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_10_3 = (RuleCall)cGroup_10.eContents().get(3);
-		private final Group cGroup_10_4 = (Group)cGroup_10.eContents().get(4);
-		private final Assignment cOutputVariablesAssignment_10_4_0 = (Assignment)cGroup_10_4.eContents().get(0);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_10_4_0_0 = (RuleCall)cOutputVariablesAssignment_10_4_0.eContents().get(0);
-		private final Group cGroup_10_4_1 = (Group)cGroup_10_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_10_4_1_0 = (RuleCall)cGroup_10_4_1.eContents().get(0);
-		private final Assignment cOutputVariablesAssignment_10_4_1_1 = (Assignment)cGroup_10_4_1.eContents().get(1);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0 = (RuleCall)cOutputVariablesAssignment_10_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_10_5 = (RuleCall)cGroup_10.eContents().get(5);
-		private final Group cGroup_11 = (Group)cGroup.eContents().get(11);
-		private final Keyword cAndKeyword_11_0 = (Keyword)cGroup_11.eContents().get(0);
-		private final Keyword cLabelKeyword_11_1 = (Keyword)cGroup_11.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_11_2 = (RuleCall)cGroup_11.eContents().get(2);
-		private final Assignment cLabelAssignment_11_3 = (Assignment)cGroup_11.eContents().get(3);
-		private final RuleCall cLabelSTRINGTerminalRuleCall_11_3_0 = (RuleCall)cLabelAssignment_11_3.eContents().get(0);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_12 = (RuleCall)cGroup.eContents().get(12);
+		private final Assignment cLabelAssignment_9_3 = (Assignment)cGroup_9.eContents().get(3);
+		private final RuleCall cLabelSTRINGTerminalRuleCall_9_3_0 = (RuleCall)cLabelAssignment_9_3.eContents().get(0);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_10 = (RuleCall)cGroup.eContents().get(10);
 		
 		//ExternalServiceTaskFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "ServiceTask"
 		//    'with' 'external' ASSOCIATION externalTopic=ExternalTopicReference
 		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    ('and' 'label' ASSOCIATION label=STRING)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
@@ -1389,8 +859,6 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//"FlowElement" name=ID ASSOCIATION "ServiceTask"
 		//'with' 'external' ASSOCIATION externalTopic=ExternalTopicReference
 		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//('and' 'label' ASSOCIATION label=STRING)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -1467,104 +935,26 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//LIST_CLOSED
 		public RuleCall getLIST_CLOSEDTerminalRuleCall_8_6() { return cLIST_CLOSEDTerminalRuleCall_8_6; }
 		
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_9() { return cGroup_9; }
-		
-		//'with'
-		public Keyword getWithKeyword_9_0() { return cWithKeyword_9_0; }
-		
-		//'inputVariables'
-		public Keyword getInputVariablesKeyword_9_1() { return cInputVariablesKeyword_9_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_9_2() { return cASSOCIATIONTerminalRuleCall_9_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_9_3() { return cLIST_OPENTerminalRuleCall_9_3; }
-		
-		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
-		public Group getGroup_9_4() { return cGroup_9_4; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_9_4_0() { return cInputVariablesAssignment_9_4_0; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_9_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_9_4_0_0; }
-		
-		//(SEPARATOR inputVariables+=VariableReference)*
-		public Group getGroup_9_4_1() { return cGroup_9_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_9_4_1_0() { return cSEPARATORTerminalRuleCall_9_4_1_0; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_9_4_1_1() { return cInputVariablesAssignment_9_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_9_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_9_5() { return cLIST_CLOSEDTerminalRuleCall_9_5; }
-		
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_10() { return cGroup_10; }
-		
-		//'with'
-		public Keyword getWithKeyword_10_0() { return cWithKeyword_10_0; }
-		
-		//'outputVariables'
-		public Keyword getOutputVariablesKeyword_10_1() { return cOutputVariablesKeyword_10_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_10_2() { return cASSOCIATIONTerminalRuleCall_10_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_10_3() { return cLIST_OPENTerminalRuleCall_10_3; }
-		
-		//(outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)?
-		public Group getGroup_10_4() { return cGroup_10_4; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_10_4_0() { return cOutputVariablesAssignment_10_4_0; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_10_4_0_0() { return cOutputVariablesVariableReferenceParserRuleCall_10_4_0_0; }
-		
-		//(SEPARATOR outputVariables+=VariableReference)*
-		public Group getGroup_10_4_1() { return cGroup_10_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_10_4_1_0() { return cSEPARATORTerminalRuleCall_10_4_1_0; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_10_4_1_1() { return cOutputVariablesAssignment_10_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0() { return cOutputVariablesVariableReferenceParserRuleCall_10_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_10_5() { return cLIST_CLOSEDTerminalRuleCall_10_5; }
-		
 		//('and' 'label' ASSOCIATION label=STRING)?
-		public Group getGroup_11() { return cGroup_11; }
+		public Group getGroup_9() { return cGroup_9; }
 		
 		//'and'
-		public Keyword getAndKeyword_11_0() { return cAndKeyword_11_0; }
+		public Keyword getAndKeyword_9_0() { return cAndKeyword_9_0; }
 		
 		//'label'
-		public Keyword getLabelKeyword_11_1() { return cLabelKeyword_11_1; }
+		public Keyword getLabelKeyword_9_1() { return cLabelKeyword_9_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_11_2() { return cASSOCIATIONTerminalRuleCall_11_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_9_2() { return cASSOCIATIONTerminalRuleCall_9_2; }
 		
 		//label=STRING
-		public Assignment getLabelAssignment_11_3() { return cLabelAssignment_11_3; }
+		public Assignment getLabelAssignment_9_3() { return cLabelAssignment_9_3; }
 		
 		//STRING
-		public RuleCall getLabelSTRINGTerminalRuleCall_11_3_0() { return cLabelSTRINGTerminalRuleCall_11_3_0; }
+		public RuleCall getLabelSTRINGTerminalRuleCall_9_3_0() { return cLabelSTRINGTerminalRuleCall_9_3_0; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_12() { return cDECLARATION_FINISHEDTerminalRuleCall_12; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_10() { return cDECLARATION_FINISHEDTerminalRuleCall_10; }
 	}
 	public class BusinessRuleTaskFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.BusinessRuleTaskFlowElement");
@@ -1581,66 +971,20 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		private final Assignment cResultVariableAssignment_4_3 = (Assignment)cGroup_4.eContents().get(3);
 		private final RuleCall cResultVariableSTRINGTerminalRuleCall_4_3_0 = (RuleCall)cResultVariableAssignment_4_3.eContents().get(0);
 		private final Group cGroup_5 = (Group)cGroup.eContents().get(5);
-		private final Keyword cWithKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
-		private final Keyword cHardcodedKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
-		private final Keyword cInputsKeyword_5_2 = (Keyword)cGroup_5.eContents().get(2);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_5_3 = (RuleCall)cGroup_5.eContents().get(3);
-		private final RuleCall cLIST_OPENTerminalRuleCall_5_4 = (RuleCall)cGroup_5.eContents().get(4);
-		private final Group cGroup_5_5 = (Group)cGroup_5.eContents().get(5);
-		private final Assignment cHardcodedInputsAssignment_5_5_0 = (Assignment)cGroup_5_5.eContents().get(0);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0 = (RuleCall)cHardcodedInputsAssignment_5_5_0.eContents().get(0);
-		private final Group cGroup_5_5_1 = (Group)cGroup_5_5.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_5_5_1_0 = (RuleCall)cGroup_5_5_1.eContents().get(0);
-		private final Assignment cHardcodedInputsAssignment_5_5_1_1 = (Assignment)cGroup_5_5_1.eContents().get(1);
-		private final RuleCall cHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0 = (RuleCall)cHardcodedInputsAssignment_5_5_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_5_6 = (RuleCall)cGroup_5.eContents().get(6);
-		private final Group cGroup_6 = (Group)cGroup.eContents().get(6);
-		private final Keyword cWithKeyword_6_0 = (Keyword)cGroup_6.eContents().get(0);
-		private final Keyword cInputVariablesKeyword_6_1 = (Keyword)cGroup_6.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_6_2 = (RuleCall)cGroup_6.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_6_3 = (RuleCall)cGroup_6.eContents().get(3);
-		private final Group cGroup_6_4 = (Group)cGroup_6.eContents().get(4);
-		private final Assignment cInputVariablesAssignment_6_4_0 = (Assignment)cGroup_6_4.eContents().get(0);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_6_4_0_0 = (RuleCall)cInputVariablesAssignment_6_4_0.eContents().get(0);
-		private final Group cGroup_6_4_1 = (Group)cGroup_6_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_6_4_1_0 = (RuleCall)cGroup_6_4_1.eContents().get(0);
-		private final Assignment cInputVariablesAssignment_6_4_1_1 = (Assignment)cGroup_6_4_1.eContents().get(1);
-		private final RuleCall cInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0 = (RuleCall)cInputVariablesAssignment_6_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_6_5 = (RuleCall)cGroup_6.eContents().get(5);
-		private final Group cGroup_7 = (Group)cGroup.eContents().get(7);
-		private final Keyword cWithKeyword_7_0 = (Keyword)cGroup_7.eContents().get(0);
-		private final Keyword cOutputVariablesKeyword_7_1 = (Keyword)cGroup_7.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_7_2 = (RuleCall)cGroup_7.eContents().get(2);
-		private final RuleCall cLIST_OPENTerminalRuleCall_7_3 = (RuleCall)cGroup_7.eContents().get(3);
-		private final Group cGroup_7_4 = (Group)cGroup_7.eContents().get(4);
-		private final Assignment cOutputVariablesAssignment_7_4_0 = (Assignment)cGroup_7_4.eContents().get(0);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_7_4_0_0 = (RuleCall)cOutputVariablesAssignment_7_4_0.eContents().get(0);
-		private final Group cGroup_7_4_1 = (Group)cGroup_7_4.eContents().get(1);
-		private final RuleCall cSEPARATORTerminalRuleCall_7_4_1_0 = (RuleCall)cGroup_7_4_1.eContents().get(0);
-		private final Assignment cOutputVariablesAssignment_7_4_1_1 = (Assignment)cGroup_7_4_1.eContents().get(1);
-		private final RuleCall cOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0 = (RuleCall)cOutputVariablesAssignment_7_4_1_1.eContents().get(0);
-		private final RuleCall cLIST_CLOSEDTerminalRuleCall_7_5 = (RuleCall)cGroup_7.eContents().get(5);
-		private final Group cGroup_8 = (Group)cGroup.eContents().get(8);
-		private final Keyword cAndKeyword_8_0 = (Keyword)cGroup_8.eContents().get(0);
-		private final Keyword cLabelKeyword_8_1 = (Keyword)cGroup_8.eContents().get(1);
-		private final RuleCall cASSOCIATIONTerminalRuleCall_8_2 = (RuleCall)cGroup_8.eContents().get(2);
-		private final Assignment cLabelAssignment_8_3 = (Assignment)cGroup_8.eContents().get(3);
-		private final RuleCall cLabelSTRINGTerminalRuleCall_8_3_0 = (RuleCall)cLabelAssignment_8_3.eContents().get(0);
-		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_9 = (RuleCall)cGroup.eContents().get(9);
+		private final Keyword cAndKeyword_5_0 = (Keyword)cGroup_5.eContents().get(0);
+		private final Keyword cLabelKeyword_5_1 = (Keyword)cGroup_5.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_5_2 = (RuleCall)cGroup_5.eContents().get(2);
+		private final Assignment cLabelAssignment_5_3 = (Assignment)cGroup_5.eContents().get(3);
+		private final RuleCall cLabelSTRINGTerminalRuleCall_5_3_0 = (RuleCall)cLabelAssignment_5_3.eContents().get(0);
+		private final RuleCall cDECLARATION_FINISHEDTerminalRuleCall_6 = (RuleCall)cGroup.eContents().get(6);
 		
 		//BusinessRuleTaskFlowElement:
 		//    "FlowElement" name=ID ASSOCIATION "BusinessRuleTask" ('with' 'resultVariable' ASSOCIATION resultVariable=STRING)?
-		//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//    ('and' 'label' ASSOCIATION label=STRING)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//"FlowElement" name=ID ASSOCIATION "BusinessRuleTask" ('with' 'resultVariable' ASSOCIATION resultVariable=STRING)?
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 		//('and' 'label' ASSOCIATION label=STRING)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -1678,146 +1022,26 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//STRING
 		public RuleCall getResultVariableSTRINGTerminalRuleCall_4_3_0() { return cResultVariableSTRINGTerminalRuleCall_4_3_0; }
 		
-		//('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-		public Group getGroup_5() { return cGroup_5; }
-		
-		//'with'
-		public Keyword getWithKeyword_5_0() { return cWithKeyword_5_0; }
-		
-		//'hardcoded'
-		public Keyword getHardcodedKeyword_5_1() { return cHardcodedKeyword_5_1; }
-		
-		//'inputs'
-		public Keyword getInputsKeyword_5_2() { return cInputsKeyword_5_2; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_5_3() { return cASSOCIATIONTerminalRuleCall_5_3; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_5_4() { return cLIST_OPENTerminalRuleCall_5_4; }
-		
-		//(hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)?
-		public Group getGroup_5_5() { return cGroup_5_5; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_5_5_0() { return cHardcodedInputsAssignment_5_5_0; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_5_5_0_0; }
-		
-		//(SEPARATOR hardcodedInputs+=VariableDeclaration)*
-		public Group getGroup_5_5_1() { return cGroup_5_5_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_5_5_1_0() { return cSEPARATORTerminalRuleCall_5_5_1_0; }
-		
-		//hardcodedInputs+=VariableDeclaration
-		public Assignment getHardcodedInputsAssignment_5_5_1_1() { return cHardcodedInputsAssignment_5_5_1_1; }
-		
-		//VariableDeclaration
-		public RuleCall getHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0() { return cHardcodedInputsVariableDeclarationParserRuleCall_5_5_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_5_6() { return cLIST_CLOSEDTerminalRuleCall_5_6; }
-		
-		//('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_6() { return cGroup_6; }
-		
-		//'with'
-		public Keyword getWithKeyword_6_0() { return cWithKeyword_6_0; }
-		
-		//'inputVariables'
-		public Keyword getInputVariablesKeyword_6_1() { return cInputVariablesKeyword_6_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_6_2() { return cASSOCIATIONTerminalRuleCall_6_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_6_3() { return cLIST_OPENTerminalRuleCall_6_3; }
-		
-		//(inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)?
-		public Group getGroup_6_4() { return cGroup_6_4; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_6_4_0() { return cInputVariablesAssignment_6_4_0; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_6_4_0_0() { return cInputVariablesVariableReferenceParserRuleCall_6_4_0_0; }
-		
-		//(SEPARATOR inputVariables+=VariableReference)*
-		public Group getGroup_6_4_1() { return cGroup_6_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_6_4_1_0() { return cSEPARATORTerminalRuleCall_6_4_1_0; }
-		
-		//inputVariables+=VariableReference
-		public Assignment getInputVariablesAssignment_6_4_1_1() { return cInputVariablesAssignment_6_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0() { return cInputVariablesVariableReferenceParserRuleCall_6_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_6_5() { return cLIST_CLOSEDTerminalRuleCall_6_5; }
-		
-		//('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
-		public Group getGroup_7() { return cGroup_7; }
-		
-		//'with'
-		public Keyword getWithKeyword_7_0() { return cWithKeyword_7_0; }
-		
-		//'outputVariables'
-		public Keyword getOutputVariablesKeyword_7_1() { return cOutputVariablesKeyword_7_1; }
-		
-		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_7_2() { return cASSOCIATIONTerminalRuleCall_7_2; }
-		
-		//LIST_OPEN
-		public RuleCall getLIST_OPENTerminalRuleCall_7_3() { return cLIST_OPENTerminalRuleCall_7_3; }
-		
-		//(outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)?
-		public Group getGroup_7_4() { return cGroup_7_4; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_7_4_0() { return cOutputVariablesAssignment_7_4_0; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_7_4_0_0() { return cOutputVariablesVariableReferenceParserRuleCall_7_4_0_0; }
-		
-		//(SEPARATOR outputVariables+=VariableReference)*
-		public Group getGroup_7_4_1() { return cGroup_7_4_1; }
-		
-		//SEPARATOR
-		public RuleCall getSEPARATORTerminalRuleCall_7_4_1_0() { return cSEPARATORTerminalRuleCall_7_4_1_0; }
-		
-		//outputVariables+=VariableReference
-		public Assignment getOutputVariablesAssignment_7_4_1_1() { return cOutputVariablesAssignment_7_4_1_1; }
-		
-		//VariableReference
-		public RuleCall getOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0() { return cOutputVariablesVariableReferenceParserRuleCall_7_4_1_1_0; }
-		
-		//LIST_CLOSED
-		public RuleCall getLIST_CLOSEDTerminalRuleCall_7_5() { return cLIST_CLOSEDTerminalRuleCall_7_5; }
-		
 		//('and' 'label' ASSOCIATION label=STRING)?
-		public Group getGroup_8() { return cGroup_8; }
+		public Group getGroup_5() { return cGroup_5; }
 		
 		//'and'
-		public Keyword getAndKeyword_8_0() { return cAndKeyword_8_0; }
+		public Keyword getAndKeyword_5_0() { return cAndKeyword_5_0; }
 		
 		//'label'
-		public Keyword getLabelKeyword_8_1() { return cLabelKeyword_8_1; }
+		public Keyword getLabelKeyword_5_1() { return cLabelKeyword_5_1; }
 		
 		//ASSOCIATION
-		public RuleCall getASSOCIATIONTerminalRuleCall_8_2() { return cASSOCIATIONTerminalRuleCall_8_2; }
+		public RuleCall getASSOCIATIONTerminalRuleCall_5_2() { return cASSOCIATIONTerminalRuleCall_5_2; }
 		
 		//label=STRING
-		public Assignment getLabelAssignment_8_3() { return cLabelAssignment_8_3; }
+		public Assignment getLabelAssignment_5_3() { return cLabelAssignment_5_3; }
 		
 		//STRING
-		public RuleCall getLabelSTRINGTerminalRuleCall_8_3_0() { return cLabelSTRINGTerminalRuleCall_8_3_0; }
+		public RuleCall getLabelSTRINGTerminalRuleCall_5_3_0() { return cLabelSTRINGTerminalRuleCall_5_3_0; }
 		
 		//DECLARATION_FINISHED
-		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_9() { return cDECLARATION_FINISHEDTerminalRuleCall_9; }
+		public RuleCall getDECLARATION_FINISHEDTerminalRuleCall_6() { return cDECLARATION_FINISHEDTerminalRuleCall_6; }
 	}
 	public class GatewayFlowElementElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.GatewayFlowElement");
@@ -1919,22 +1143,42 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	}
 	public class FlowElementReferenceElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.FlowElementReference");
-		private final Assignment cRefAssignment = (Assignment)rule.eContents().get(1);
-		private final CrossReference cRefFlowElementCrossReference_0 = (CrossReference)cRefAssignment.eContents().get(0);
-		private final RuleCall cRefFlowElementIDTerminalRuleCall_0_1 = (RuleCall)cRefFlowElementCrossReference_0.eContents().get(1);
+		private final Group cGroup = (Group)rule.eContents().get(1);
+		private final Assignment cRefAssignment_0 = (Assignment)cGroup.eContents().get(0);
+		private final CrossReference cRefFlowElementCrossReference_0_0 = (CrossReference)cRefAssignment_0.eContents().get(0);
+		private final RuleCall cRefFlowElementIDTerminalRuleCall_0_0_1 = (RuleCall)cRefFlowElementCrossReference_0_0.eContents().get(1);
+		private final Group cGroup_1 = (Group)cGroup.eContents().get(1);
+		private final RuleCall cASSOCIATIONTerminalRuleCall_1_0 = (RuleCall)cGroup_1.eContents().get(0);
+		private final Assignment cFlagAssignment_1_1 = (Assignment)cGroup_1.eContents().get(1);
+		private final RuleCall cFlagFlagEnumRuleCall_1_1_0 = (RuleCall)cFlagAssignment_1_1.eContents().get(0);
 		
 		//FlowElementReference:
-		//    ref=[FlowElement] ;
+		//    ref=[FlowElement] (ASSOCIATION flag=Flag)? ;
 		@Override public ParserRule getRule() { return rule; }
 		
+		//ref=[FlowElement] (ASSOCIATION flag=Flag)?
+		public Group getGroup() { return cGroup; }
+		
 		//ref=[FlowElement]
-		public Assignment getRefAssignment() { return cRefAssignment; }
+		public Assignment getRefAssignment_0() { return cRefAssignment_0; }
 		
 		//[FlowElement]
-		public CrossReference getRefFlowElementCrossReference_0() { return cRefFlowElementCrossReference_0; }
+		public CrossReference getRefFlowElementCrossReference_0_0() { return cRefFlowElementCrossReference_0_0; }
 		
 		//ID
-		public RuleCall getRefFlowElementIDTerminalRuleCall_0_1() { return cRefFlowElementIDTerminalRuleCall_0_1; }
+		public RuleCall getRefFlowElementIDTerminalRuleCall_0_0_1() { return cRefFlowElementIDTerminalRuleCall_0_0_1; }
+		
+		//(ASSOCIATION flag=Flag)?
+		public Group getGroup_1() { return cGroup_1; }
+		
+		//ASSOCIATION
+		public RuleCall getASSOCIATIONTerminalRuleCall_1_0() { return cASSOCIATIONTerminalRuleCall_1_0; }
+		
+		//flag=Flag
+		public Assignment getFlagAssignment_1_1() { return cFlagAssignment_1_1; }
+		
+		//Flag
+		public RuleCall getFlagFlagEnumRuleCall_1_1_0() { return cFlagFlagEnumRuleCall_1_1_0; }
 	}
 	public class DelegateServiceTaskReferenceElements extends AbstractParserRuleElementFinder {
 		private final ParserRule rule = (ParserRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.DelegateServiceTaskReference");
@@ -2472,14 +1716,14 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//Flow:
 		//    'Flow' name=ID 'for' bpmnReference=BPMNReference
 		//    ('with' 'flag' ASSOCIATION flag=Flag)?
-		//    'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference )*)? LIST_CLOSED
+		//    'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference)*)? LIST_CLOSED
 		//    ('without' 'elements' ASSOCIATION LIST_OPEN (exclElements+=FlowElementReference (SEPARATOR exclElements+=FlowElementReference)*)? LIST_CLOSED)?
 		//    DECLARATION_FINISHED;
 		@Override public ParserRule getRule() { return rule; }
 		
 		//'Flow' name=ID 'for' bpmnReference=BPMNReference
 		//('with' 'flag' ASSOCIATION flag=Flag)?
-		//'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference )*)? LIST_CLOSED
+		//'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference)*)? LIST_CLOSED
 		//('without' 'elements' ASSOCIATION LIST_OPEN (exclElements+=FlowElementReference (SEPARATOR exclElements+=FlowElementReference)*)? LIST_CLOSED)?
 		//DECLARATION_FINISHED
 		public Group getGroup() { return cGroup; }
@@ -2532,7 +1776,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//LIST_OPEN
 		public RuleCall getLIST_OPENTerminalRuleCall_8() { return cLIST_OPENTerminalRuleCall_8; }
 		
-		//(inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference )*)?
+		//(inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference)*)?
 		public Group getGroup_9() { return cGroup_9; }
 		
 		//inclElements+=FlowElementReference
@@ -2541,7 +1785,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 		//FlowElementReference
 		public RuleCall getInclElementsFlowElementReferenceParserRuleCall_9_0_0() { return cInclElementsFlowElementReferenceParserRuleCall_9_0_0; }
 		
-		//(SEPARATOR inclElements+=FlowElementReference )*
+		//(SEPARATOR inclElements+=FlowElementReference)*
 		public Group getGroup_9_1() { return cGroup_9_1; }
 		
 		//SEPARATOR
@@ -3959,41 +3203,51 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	public class FlagElements extends AbstractElementFinder.AbstractEnumRuleElementFinder {
 		private final EnumRule rule = (EnumRule) GrammarUtil.findRuleForName(getGrammar(), "de.fhmuenster.masterthesis.TestgeneratorDSL.Flag");
 		private final Alternatives cAlternatives = (Alternatives)rule.eContents().get(1);
-		private final EnumLiteralDeclaration cGREENEnumLiteralDeclaration_0 = (EnumLiteralDeclaration)cAlternatives.eContents().get(0);
-		private final Keyword cGREENGREENKeyword_0_0 = (Keyword)cGREENEnumLiteralDeclaration_0.eContents().get(0);
-		private final EnumLiteralDeclaration cYELLOWEnumLiteralDeclaration_1 = (EnumLiteralDeclaration)cAlternatives.eContents().get(1);
-		private final Keyword cYELLOWYELLOWKeyword_1_0 = (Keyword)cYELLOWEnumLiteralDeclaration_1.eContents().get(0);
-		private final EnumLiteralDeclaration cREDEnumLiteralDeclaration_2 = (EnumLiteralDeclaration)cAlternatives.eContents().get(2);
-		private final Keyword cREDREDKeyword_2_0 = (Keyword)cREDEnumLiteralDeclaration_2.eContents().get(0);
+		private final EnumLiteralDeclaration cNONEEnumLiteralDeclaration_0 = (EnumLiteralDeclaration)cAlternatives.eContents().get(0);
+		private final Keyword cNONENONEKeyword_0_0 = (Keyword)cNONEEnumLiteralDeclaration_0.eContents().get(0);
+		private final EnumLiteralDeclaration cGREENEnumLiteralDeclaration_1 = (EnumLiteralDeclaration)cAlternatives.eContents().get(1);
+		private final Keyword cGREENGREENKeyword_1_0 = (Keyword)cGREENEnumLiteralDeclaration_1.eContents().get(0);
+		private final EnumLiteralDeclaration cYELLOWEnumLiteralDeclaration_2 = (EnumLiteralDeclaration)cAlternatives.eContents().get(2);
+		private final Keyword cYELLOWYELLOWKeyword_2_0 = (Keyword)cYELLOWEnumLiteralDeclaration_2.eContents().get(0);
+		private final EnumLiteralDeclaration cREDEnumLiteralDeclaration_3 = (EnumLiteralDeclaration)cAlternatives.eContents().get(3);
+		private final Keyword cREDREDKeyword_3_0 = (Keyword)cREDEnumLiteralDeclaration_3.eContents().get(0);
 		
 		//enum Flag:
+		//    NONE = "NONE" |
 		//    GREEN = "GREEN" |
 		//    YELLOW = "YELLOW" |
 		//    RED = "RED";
 		public EnumRule getRule() { return rule; }
 		
+		//NONE = "NONE" |
 		//GREEN = "GREEN" |
 		//YELLOW = "YELLOW" |
 		//RED = "RED"
 		public Alternatives getAlternatives() { return cAlternatives; }
 		
+		//NONE = "NONE"
+		public EnumLiteralDeclaration getNONEEnumLiteralDeclaration_0() { return cNONEEnumLiteralDeclaration_0; }
+		
+		//"NONE"
+		public Keyword getNONENONEKeyword_0_0() { return cNONENONEKeyword_0_0; }
+		
 		//GREEN = "GREEN"
-		public EnumLiteralDeclaration getGREENEnumLiteralDeclaration_0() { return cGREENEnumLiteralDeclaration_0; }
+		public EnumLiteralDeclaration getGREENEnumLiteralDeclaration_1() { return cGREENEnumLiteralDeclaration_1; }
 		
 		//"GREEN"
-		public Keyword getGREENGREENKeyword_0_0() { return cGREENGREENKeyword_0_0; }
+		public Keyword getGREENGREENKeyword_1_0() { return cGREENGREENKeyword_1_0; }
 		
 		//YELLOW = "YELLOW"
-		public EnumLiteralDeclaration getYELLOWEnumLiteralDeclaration_1() { return cYELLOWEnumLiteralDeclaration_1; }
+		public EnumLiteralDeclaration getYELLOWEnumLiteralDeclaration_2() { return cYELLOWEnumLiteralDeclaration_2; }
 		
 		//"YELLOW"
-		public Keyword getYELLOWYELLOWKeyword_1_0() { return cYELLOWYELLOWKeyword_1_0; }
+		public Keyword getYELLOWYELLOWKeyword_2_0() { return cYELLOWYELLOWKeyword_2_0; }
 		
 		//RED = "RED"
-		public EnumLiteralDeclaration getREDEnumLiteralDeclaration_2() { return cREDEnumLiteralDeclaration_2; }
+		public EnumLiteralDeclaration getREDEnumLiteralDeclaration_3() { return cREDEnumLiteralDeclaration_3; }
 		
 		//"RED"
-		public Keyword getREDREDKeyword_2_0() { return cREDREDKeyword_2_0; }
+		public Keyword getREDREDKeyword_3_0() { return cREDREDKeyword_3_0; }
 	}
 	
 	private final ModelElements pModel;
@@ -4223,8 +3477,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	
 	//StartFlowElement:
 	//    "FlowElement" name=ID ASSOCIATION "StartEvent"
-	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-	//    ('with' 'startVariables' ASSOCIATION LIST_OPEN (startVariables+=VariableReference (SEPARATOR startVariables+=VariableReference)*)? LIST_CLOSED)?
+	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    DECLARATION_FINISHED;
 	public StartFlowElementElements getStartFlowElementAccess() {
 		return pStartFlowElement;
@@ -4246,9 +3499,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	
 	//UserTaskFlowElement:
 	//    "FlowElement" name=ID ASSOCIATION "UserTask"
-	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
 	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-	//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    ('and' 'label' ASSOCIATION label=STRING)?
 	//    DECLARATION_FINISHED;
 	public UserTaskFlowElementElements getUserTaskFlowElementAccess() {
@@ -4261,9 +3512,6 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	
 	//ManualTaskFlowElement:
 	//    "FlowElement" name=ID ASSOCIATION "ManualTask"
-	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-	//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    ('and' 'label' ASSOCIATION label=STRING)?
 	//    DECLARATION_FINISHED;
 	public ManualTaskFlowElementElements getManualTaskFlowElementAccess() {
@@ -4276,9 +3524,6 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	
 	//ScriptTaskFlowElement:
 	//    "FlowElement" name=ID ASSOCIATION "ScriptTask"
-	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-	//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    ('and' 'label' ASSOCIATION label=STRING)?
 	//    DECLARATION_FINISHED;
 	public ScriptTaskFlowElementElements getScriptTaskFlowElementAccess() {
@@ -4316,8 +3561,6 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	//    "FlowElement" name=ID ASSOCIATION "ServiceTask"
 	//    'with' 'external' ASSOCIATION externalTopic=ExternalTopicReference
 	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-	//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    ('and' 'label' ASSOCIATION label=STRING)?
 	//    DECLARATION_FINISHED;
 	public ExternalServiceTaskFlowElementElements getExternalServiceTaskFlowElementAccess() {
@@ -4330,9 +3573,6 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	
 	//BusinessRuleTaskFlowElement:
 	//    "FlowElement" name=ID ASSOCIATION "BusinessRuleTask" ('with' 'resultVariable' ASSOCIATION resultVariable=STRING)?
-	//    ('with' 'hardcoded' 'inputs' ASSOCIATION LIST_OPEN (hardcodedInputs+=VariableDeclaration (SEPARATOR hardcodedInputs+=VariableDeclaration)*)? LIST_CLOSED)?
-	//    ('with' 'inputVariables' ASSOCIATION LIST_OPEN (inputVariables+=VariableReference (SEPARATOR inputVariables+=VariableReference)*)? LIST_CLOSED)?
-	//    ('with' 'outputVariables' ASSOCIATION LIST_OPEN (outputVariables+=VariableReference (SEPARATOR outputVariables+=VariableReference)*)? LIST_CLOSED)?
 	//    ('and' 'label' ASSOCIATION label=STRING)?
 	//    DECLARATION_FINISHED;
 	public BusinessRuleTaskFlowElementElements getBusinessRuleTaskFlowElementAccess() {
@@ -4366,7 +3606,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	}
 	
 	//FlowElementReference:
-	//    ref=[FlowElement] ;
+	//    ref=[FlowElement] (ASSOCIATION flag=Flag)? ;
 	public FlowElementReferenceElements getFlowElementReferenceAccess() {
 		return pFlowElementReference;
 	}
@@ -4491,7 +3731,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	//Flow:
 	//    'Flow' name=ID 'for' bpmnReference=BPMNReference
 	//    ('with' 'flag' ASSOCIATION flag=Flag)?
-	//    'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference )*)? LIST_CLOSED
+	//    'with' 'elements' ASSOCIATION LIST_OPEN (inclElements+=FlowElementReference (SEPARATOR inclElements+=FlowElementReference)*)? LIST_CLOSED
 	//    ('without' 'elements' ASSOCIATION LIST_OPEN (exclElements+=FlowElementReference (SEPARATOR exclElements+=FlowElementReference)*)? LIST_CLOSED)?
 	//    DECLARATION_FINISHED;
 	public FlowElements getFlowAccess() {
@@ -4822,6 +4062,7 @@ public class TestgeneratorDSLGrammarAccess extends AbstractElementFinder.Abstrac
 	}
 	
 	//enum Flag:
+	//    NONE = "NONE" |
 	//    GREEN = "GREEN" |
 	//    YELLOW = "YELLOW" |
 	//    RED = "RED";
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/Flag.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/Flag.java
index 48a40a468b1d95fb772deb102d94f48703b6323c..1b06f65a8c24ce4ceacf564b292867b054e6d51a 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/Flag.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/Flag.java
@@ -20,6 +20,16 @@ import org.eclipse.emf.common.util.Enumerator;
  */
 public enum Flag implements Enumerator
 {
+  /**
+   * The '<em><b>NONE</b></em>' literal object.
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @see #NONE_VALUE
+   * @generated
+   * @ordered
+   */
+  NONE(0, "NONE", "NONE"),
+
   /**
    * The '<em><b>GREEN</b></em>' literal object.
    * <!-- begin-user-doc -->
@@ -28,7 +38,7 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  GREEN(0, "GREEN", "GREEN"),
+  GREEN(1, "GREEN", "GREEN"),
 
   /**
    * The '<em><b>YELLOW</b></em>' literal object.
@@ -38,7 +48,7 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  YELLOW(1, "YELLOW", "YELLOW"),
+  YELLOW(2, "YELLOW", "YELLOW"),
 
   /**
    * The '<em><b>RED</b></em>' literal object.
@@ -48,7 +58,18 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  RED(2, "RED", "RED");
+  RED(3, "RED", "RED");
+
+  /**
+   * The '<em><b>NONE</b></em>' literal value.
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @see #NONE
+   * @model
+   * @generated
+   * @ordered
+   */
+  public static final int NONE_VALUE = 0;
 
   /**
    * The '<em><b>GREEN</b></em>' literal value.
@@ -59,7 +80,7 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  public static final int GREEN_VALUE = 0;
+  public static final int GREEN_VALUE = 1;
 
   /**
    * The '<em><b>YELLOW</b></em>' literal value.
@@ -70,7 +91,7 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  public static final int YELLOW_VALUE = 1;
+  public static final int YELLOW_VALUE = 2;
 
   /**
    * The '<em><b>RED</b></em>' literal value.
@@ -81,7 +102,7 @@ public enum Flag implements Enumerator
    * @generated
    * @ordered
    */
-  public static final int RED_VALUE = 2;
+  public static final int RED_VALUE = 3;
 
   /**
    * An array of all the '<em><b>Flag</b></em>' enumerators.
@@ -92,6 +113,7 @@ public enum Flag implements Enumerator
   private static final Flag[] VALUES_ARRAY =
     new Flag[]
     {
+      NONE,
       GREEN,
       YELLOW,
       RED,
@@ -159,6 +181,7 @@ public enum Flag implements Enumerator
   {
     switch (value)
     {
+      case NONE_VALUE: return NONE;
       case GREEN_VALUE: return GREEN;
       case YELLOW_VALUE: return YELLOW;
       case RED_VALUE: return RED;
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowElementReferenceImpl.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowElementReferenceImpl.java
index 57741556e84d1ece67d8ec95d8a2182619cc233c..dcdf1b3bc8aff3ac18ede6fa3bfc0b483ddb6fe9 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowElementReferenceImpl.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowElementReferenceImpl.java
@@ -3,6 +3,7 @@
  */
 package de.fhmuenster.masterthesis.testgeneratorDSL.impl;
 
+import de.fhmuenster.masterthesis.testgeneratorDSL.Flag;
 import de.fhmuenster.masterthesis.testgeneratorDSL.FlowElement;
 import de.fhmuenster.masterthesis.testgeneratorDSL.FlowElementReference;
 import de.fhmuenster.masterthesis.testgeneratorDSL.TestgeneratorDSLPackage;
@@ -24,6 +25,7 @@ import org.eclipse.emf.ecore.impl.MinimalEObjectImpl;
  * </p>
  * <ul>
  *   <li>{@link de.fhmuenster.masterthesis.testgeneratorDSL.impl.FlowElementReferenceImpl#getRef <em>Ref</em>}</li>
+ *   <li>{@link de.fhmuenster.masterthesis.testgeneratorDSL.impl.FlowElementReferenceImpl#getFlag <em>Flag</em>}</li>
  * </ul>
  *
  * @generated
@@ -40,6 +42,26 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
    */
   protected FlowElement ref;
 
+  /**
+   * The default value of the '{@link #getFlag() <em>Flag</em>}' attribute.
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @see #getFlag()
+   * @generated
+   * @ordered
+   */
+  protected static final Flag FLAG_EDEFAULT = Flag.NONE;
+
+  /**
+   * The cached value of the '{@link #getFlag() <em>Flag</em>}' attribute.
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @see #getFlag()
+   * @generated
+   * @ordered
+   */
+  protected Flag flag = FLAG_EDEFAULT;
+
   /**
    * <!-- begin-user-doc -->
    * <!-- end-user-doc -->
@@ -106,6 +128,31 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
       eNotify(new ENotificationImpl(this, Notification.SET, TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__REF, oldRef, ref));
   }
 
+  /**
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @generated
+   */
+  @Override
+  public Flag getFlag()
+  {
+    return flag;
+  }
+
+  /**
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @generated
+   */
+  @Override
+  public void setFlag(Flag newFlag)
+  {
+    Flag oldFlag = flag;
+    flag = newFlag == null ? FLAG_EDEFAULT : newFlag;
+    if (eNotificationRequired())
+      eNotify(new ENotificationImpl(this, Notification.SET, TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__FLAG, oldFlag, flag));
+  }
+
   /**
    * <!-- begin-user-doc -->
    * <!-- end-user-doc -->
@@ -119,6 +166,8 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
       case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__REF:
         if (resolve) return getRef();
         return basicGetRef();
+      case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__FLAG:
+        return getFlag();
     }
     return super.eGet(featureID, resolve, coreType);
   }
@@ -136,6 +185,9 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
       case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__REF:
         setRef((FlowElement)newValue);
         return;
+      case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__FLAG:
+        setFlag((Flag)newValue);
+        return;
     }
     super.eSet(featureID, newValue);
   }
@@ -153,6 +205,9 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
       case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__REF:
         setRef((FlowElement)null);
         return;
+      case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__FLAG:
+        setFlag(FLAG_EDEFAULT);
+        return;
     }
     super.eUnset(featureID);
   }
@@ -169,8 +224,27 @@ public class FlowElementReferenceImpl extends MinimalEObjectImpl.Container imple
     {
       case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__REF:
         return ref != null;
+      case TestgeneratorDSLPackage.FLOW_ELEMENT_REFERENCE__FLAG:
+        return flag != FLAG_EDEFAULT;
     }
     return super.eIsSet(featureID);
   }
 
+  /**
+   * <!-- begin-user-doc -->
+   * <!-- end-user-doc -->
+   * @generated
+   */
+  @Override
+  public String toString()
+  {
+    if (eIsProxy()) return super.toString();
+
+    StringBuilder result = new StringBuilder(super.toString());
+    result.append(" (flag: ");
+    result.append(flag);
+    result.append(')');
+    return result.toString();
+  }
+
 } //FlowElementReferenceImpl
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowImpl.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowImpl.java
index 24df0e65fbb6401fa28b6f833d4b3b89973e7618..0d707c155cc55125f77bbe61b82e8f93054552b5 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowImpl.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/FlowImpl.java
@@ -60,7 +60,7 @@ public class FlowImpl extends DeclarationImpl implements Flow
    * @generated
    * @ordered
    */
-  protected static final Flag FLAG_EDEFAULT = Flag.GREEN;
+  protected static final Flag FLAG_EDEFAULT = Flag.NONE;
 
   /**
    * The cached value of the '{@link #getFlag() <em>Flag</em>}' attribute.
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/TestgeneratorDSLPackageImpl.java b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/TestgeneratorDSLPackageImpl.java
index 02c11eda2f5596346458862e203308369ded0205..1f0cb4135073e1f1d511f4329573a48d946bfd08 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/TestgeneratorDSLPackageImpl.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src-gen/de/fhmuenster/masterthesis/testgeneratorDSL/impl/TestgeneratorDSLPackageImpl.java
@@ -2799,6 +2799,7 @@ public class TestgeneratorDSLPackageImpl extends EPackageImpl implements Testgen
     addEEnumLiteral(booleanCompareSymbolEEnum, BooleanCompareSymbol.NOT_EQUALS);
 
     initEEnum(flagEEnum, Flag.class, "Flag");
+    addEEnumLiteral(flagEEnum, Flag.NONE);
     addEEnumLiteral(flagEEnum, Flag.GREEN);
     addEEnumLiteral(flagEEnum, Flag.YELLOW);
     addEEnumLiteral(flagEEnum, Flag.RED);
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/TestgeneratorDSL.xtext b/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/TestgeneratorDSL.xtext
index 213d2986ac1486ebe4c1ee3160c6361a496306ed..198f3783a267d86f5c68effe8179d44114998edf 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/TestgeneratorDSL.xtext
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/TestgeneratorDSL.xtext
@@ -91,7 +91,7 @@ SequenceFlowElement:
 	DECLARATION_FINISHED;
 	
 FlowElementReference:
-	ref=[FlowElement] ;
+	ref=[FlowElement] (ASSOCIATION flag=Flag)? ;
 	
 DelegateServiceTaskReference:
 	ref=[DelegateServiceTaskFlowElement];
@@ -253,6 +253,7 @@ enum BooleanCompareSymbol:
 	NOT_EQUALS = "!=";
 	
 enum Flag:
+	NONE = "NONE" |
 	GREEN = "GREEN" |
 	YELLOW = "YELLOW" |
 	RED = "RED";
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/serialization/TestgeneratorDSLSerializer.java b/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/serialization/TestgeneratorDSLSerializer.java
index 56ffdf4b0929b3ef618f9abd67efec2c9cb1c7a8..4e0c681e332e8e3d821c12fea5bb2a367b3ea407 100644
--- a/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/serialization/TestgeneratorDSLSerializer.java
+++ b/de.fhmuenster.masterthesis.textgeneratordsl/src/de/fhmuenster/masterthesis/serialization/TestgeneratorDSLSerializer.java
@@ -4,6 +4,7 @@ import java.io.File;
 import java.io.FileWriter;
 import java.io.IOException;
 import java.util.ArrayList;
+import java.util.Collections;
 import java.util.Comparator;
 import java.util.List;
 import java.util.Map;
@@ -11,6 +12,7 @@ import java.util.Optional;
 import java.util.function.Function;
 import java.util.stream.Collectors;
 
+import org.eclipse.emf.common.util.BasicEList;
 import org.eclipse.emf.common.util.EList;
 import org.eclipse.emf.common.util.URI;
 import org.eclipse.emf.ecore.resource.Resource;
@@ -25,13 +27,16 @@ import de.fhmuenster.masterthesis.TestgeneratorDSLRuntimeModule;
 import de.fhmuenster.masterthesis.TestgeneratorDSLStandaloneSetup;
 import de.fhmuenster.masterthesis.testgeneratorDSL.BPMNDiagram;
 import de.fhmuenster.masterthesis.testgeneratorDSL.BooleanVariable;
+import de.fhmuenster.masterthesis.testgeneratorDSL.Declaration;
 import de.fhmuenster.masterthesis.testgeneratorDSL.DelegateMock;
 import de.fhmuenster.masterthesis.testgeneratorDSL.DelegateServiceTaskFlowElement;
 import de.fhmuenster.masterthesis.testgeneratorDSL.ExternalServiceMock;
 import de.fhmuenster.masterthesis.testgeneratorDSL.ExternalServiceTaskFlowElement;
 import de.fhmuenster.masterthesis.testgeneratorDSL.ExternalTopic;
+import de.fhmuenster.masterthesis.testgeneratorDSL.Flag;
 import de.fhmuenster.masterthesis.testgeneratorDSL.Flow;
 import de.fhmuenster.masterthesis.testgeneratorDSL.FlowElement;
+import de.fhmuenster.masterthesis.testgeneratorDSL.FlowElementReference;
 import de.fhmuenster.masterthesis.testgeneratorDSL.IntVariable;
 import de.fhmuenster.masterthesis.testgeneratorDSL.Loop;
 import de.fhmuenster.masterthesis.testgeneratorDSL.Mock;
@@ -430,6 +435,52 @@ public class TestgeneratorDSLSerializer {
 		
 		return findFirst.isPresent() ? findFirst.get() : null;
 	}
+	
+	public EList<FlowElementReference> updateInclElements(EList<FlowElementReference> fers, String flowName) {
+		/*
+		return model.getDeclarations().stream() //
+				.filter(d -> d instanceof FlowElementReference) //
+				.map(fer -> ((FlowElementReference) fer)) //
+				.filter(fer -> fer.getRef().get) //
+				.collect(Collectors.toList()); //
+		
+		
+		for(Declaration d : model.getDeclarations()) {
+			if(d instanceof FlowElement) {
+				Flow mappedFlow = (Flow) d;
+				if(mappedFlow.getName().equals(f.getName())) {
+					mappedFlow.getInclElements()
+				}
+			}
+		}
+		*/
+		
+		//Flow flow = this.getFlow(flowName);
+		
+		Flow flow = this.getFlow(flowName);
+		EList<FlowElementReference> newFers = new BasicEList<>();
+		//Collections.copy(newFers, f.getInclElements());
+		
+		
+		
+		for(FlowElementReference r : fers) {
+			FlowElementReference ref = TestgeneratorDSLFactory.eINSTANCE.createFlowElementReference();
+			System.out.println("Ausgabe von den alten fers : " + r.getFlag());
+			//ref.setFlag(Flag.YELLOW);
+			ref.setRef(r.getRef());
+			ref.setFlag(r.getFlag());
+			
+			//this.getFlowElements(null)
+			
+			newFers.add(ref);
+		}
+		
+		flow.getInclElements().clear();
+		flow.getInclElements().addAll(newFers);
+		
+		
+		return newFers;
+	}
 
 	public void serialize() throws IOException {
 		String serialized = serializer.serialize(model);
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLRuntimeModule.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLRuntimeModule.xtendbin
index 29f90ff2af1c831fa27da1115befa2a77ac24621..67f6b58d3b36f8fa94641ed367150aeb78065081 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLRuntimeModule.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLRuntimeModule.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLStandaloneSetup.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLStandaloneSetup.xtendbin
index 53541d8849dc14edaec3bcbe0b657bb93b2a98f2..be9734292dfd047a94c513844ce16a52bf952a10 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLStandaloneSetup.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/.TestgeneratorDSLStandaloneSetup.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/formatting2/.TestgeneratorDSLFormatter.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/formatting2/.TestgeneratorDSLFormatter.xtendbin
index 758764cf4af18353408a50bcaa5e2d9c6d530bcd..ec72972a08cb2fcc214cb8f3dbb24519e1f7a955 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/formatting2/.TestgeneratorDSLFormatter.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/formatting2/.TestgeneratorDSLFormatter.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/generator/.TestgeneratorDSLGenerator.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/generator/.TestgeneratorDSLGenerator.xtendbin
index 68fdbff62753465b198eaa9f4cc056041eb24ee9..28acec61cd07a73e1e83b2ad2fcd779f51253fd1 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/generator/.TestgeneratorDSLGenerator.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/generator/.TestgeneratorDSLGenerator.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/scoping/.TestgeneratorDSLScopeProvider.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/scoping/.TestgeneratorDSLScopeProvider.xtendbin
index 1d7d416b8225285c744b70269cc714ffd3fcf4d6..188105651b23baa83ecd80de80bc23a42238beb0 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/scoping/.TestgeneratorDSLScopeProvider.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/scoping/.TestgeneratorDSLScopeProvider.xtendbin differ
diff --git a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/validation/.TestgeneratorDSLValidator.xtendbin b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/validation/.TestgeneratorDSLValidator.xtendbin
index a7db444eaacd710a79aeaa45d5e3dcb50d08f72d..1b590762a701f96360e9c43142b3d465e30796c9 100644
Binary files a/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/validation/.TestgeneratorDSLValidator.xtendbin and b/de.fhmuenster.masterthesis.textgeneratordsl/xtend-gen/de/fhmuenster/masterthesis/validation/.TestgeneratorDSLValidator.xtendbin differ