Changeset 2008
- Timestamp:
- 07/14/15 11:45:13 (10 years ago)
- Location:
- trunk/autoquest-plugin-uml/src/main/java/de/ugoe/cs/autoquest/plugin/uml
- Files:
-
- 1 added
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/autoquest-plugin-uml/src/main/java/de/ugoe/cs/autoquest/plugin/uml/UMLUtils.java
r2005 r2008 30 30 import java.util.logging.Level; 31 31 32 import org.apache.commons.lang.mutable.MutableInt;33 32 import org.eclipse.emf.common.util.EList; 34 33 import org.eclipse.uml2.uml.Activity; 35 34 import org.eclipse.uml2.uml.ActivityEdge; 36 35 import org.eclipse.uml2.uml.ActivityNode; 37 import org.eclipse.uml2.uml.CallConcurrencyKind;38 36 import org.eclipse.uml2.uml.CallEvent; 39 37 import org.eclipse.uml2.uml.CallOperationAction; … … 42 40 import org.eclipse.uml2.uml.Connector; 43 41 import org.eclipse.uml2.uml.ConnectorEnd; 44 import org.eclipse.uml2.uml.DataType;45 42 import org.eclipse.uml2.uml.Element; 46 43 import org.eclipse.uml2.uml.Expression; 47 import org.eclipse.uml2.uml.InstanceSpecification;48 import org.eclipse.uml2.uml.InstanceValue;49 44 import org.eclipse.uml2.uml.Interaction; 50 45 import org.eclipse.uml2.uml.InteractionFragment; … … 67 62 import org.eclipse.uml2.uml.Property; 68 63 import org.eclipse.uml2.uml.Region; 69 import org.eclipse.uml2.uml.Slot;70 64 import org.eclipse.uml2.uml.StateMachine; 71 65 import org.eclipse.uml2.uml.Stereotype; … … 426 420 * Name of the test context that should be used. If this value is null, the first 427 421 * test context found is used. 428 * @param useRandom RequestBodies422 * @param useRandomMsgBodies 429 423 * defines is random request bodies are used or the body of the associated event 430 424 */ … … 433 427 String interactionName, 434 428 String testContextName, 435 boolean useRandom RequestBodies)429 boolean useRandomMsgBodies) 436 430 { 437 final Component testContext = fetchTestContext(model, testContextName); 438 if (testContext == null) { 439 throw new RuntimeException("Could not find any test context in the model"); 440 } 441 442 final Operation operation = testContext.createOwnedOperation(interactionName, null, null); 443 operation.applyStereotype(UTPUtils.getTestCaseStereotype(model)); 444 445 final Interaction interaction = 446 (Interaction) testContext.createPackagedElement(interactionName + "_Impl", 447 UMLPackage.Literals.INTERACTION); 448 operation.getMethods().add(interaction); 449 450 // create lifelines 451 Lifeline userLifeline = null; 452 453 for (Property property : fetchAllSUTProperties(testContext)) { 454 String serviceName = property.getName(); 455 Lifeline targetLifeline = interaction.createLifeline(serviceName); 456 targetLifeline.setRepresents(property); 457 } 458 for (Property property : fetchAllTestComponentProperties(testContext)) { 459 userLifeline = interaction.createLifeline(property.getName()); 460 userLifeline.setRepresents(property); 461 } 462 463 if (userLifeline == null) { 464 throw new RuntimeException("No TestComponent found, could not create user lifeline."); 465 } 466 if (interaction.getLifelines().size() < 2) { 467 throw new RuntimeException("Fewer than two lifelines created. No SUT found."); 468 } 469 470 int i = 0; 471 for (Event event : sequence) { 472 if (!(event.equals(Event.STARTEVENT) || event.equals(Event.ENDEVENT))) { 473 String serviceName = SOAPUtils.getServiceNameFromEvent(event); 474 String methodName = SOAPUtils.getCalledMethodFromEvent(event); 475 String clientName = SOAPUtils.getClientNameFromEvent(event); 476 String prefix = interactionName + "_" + i + "_" + methodName + "_"; 477 // determine lifelines 478 Lifeline msgTargetLifeline; 479 Lifeline msgSourceLifeline; 480 481 msgSourceLifeline = interaction.getLifeline(clientName); 482 msgTargetLifeline = interaction.getLifeline(serviceName); 483 484 if (msgSourceLifeline == null) { 485 throw new RuntimeException( 486 "Error creating message: could not determine source lifeline for component: " + 487 clientName); 488 } 489 if (msgTargetLifeline == null) { 490 throw new RuntimeException( 491 "Error creating message: could not determine target lifeline for component: " + 492 serviceName); 493 } 494 // determine correct target interface 495 Set<Interface> targetInterfaces = 496 getRealizedInterfacesFromProperty((Property) msgTargetLifeline.getRepresents()); 497 if (targetInterfaces.isEmpty()) { 498 throw new RuntimeException("no interface associated with the property " + 499 msgTargetLifeline.getRepresents().getName()); 500 } 501 Interface targetInterface = null; 502 for (Interface intface : targetInterfaces) { 503 if (getOperationFromName(intface.getOperations(), methodName) != null) { 504 // interface found 505 targetInterface = intface; 506 break; 507 } 508 } 509 if (targetInterface == null) { 510 StringBuilder errStrBuilder = new StringBuilder(); 511 errStrBuilder 512 .append("Error creating message: operation not found in the implementing interfaces ("); 513 Iterator<Interface> iter = targetInterfaces.iterator(); 514 while (iter.hasNext()) { 515 String interfaceName = iter.next().getName(); 516 errStrBuilder.append(interfaceName); 517 if (iter.hasNext()) { 518 errStrBuilder.append(","); 519 } 520 else { 521 errStrBuilder.append("): " + methodName); 522 } 523 } 524 throw new RuntimeException(errStrBuilder.toString()); 525 } 526 527 Operation calledOperation = 528 getOperationFromName(targetInterface.getOperations(), methodName); 529 // get connector 530 Connector connector = 531 inferConnector(msgSourceLifeline, msgTargetLifeline, targetInterface); 532 if (connector == null) { 533 throw new RuntimeException( 534 "Error creating message: could not find connector between the two life lines that supports the target interface at the target lifeline"); 535 } 536 537 boolean asynch = false; 538 if (calledOperation.getConcurrency() == CallConcurrencyKind.CONCURRENT_LITERAL) { 539 asynch = true; 540 } 541 542 if (SOAPUtils.isSOAPRequest(event)) { 543 // setup for both SYNCH and ASYNCH calls 544 MessageOccurrenceSpecification callSendFragment = 545 (MessageOccurrenceSpecification) interaction 546 .createFragment(prefix + "callSendFragment", 547 UMLPackage.Literals.MESSAGE_OCCURRENCE_SPECIFICATION); 548 MessageOccurrenceSpecification callRecvFragment = 549 (MessageOccurrenceSpecification) interaction 550 .createFragment(prefix + "callRecvFragment", 551 UMLPackage.Literals.MESSAGE_OCCURRENCE_SPECIFICATION); 552 553 callSendFragment.setCovered(msgSourceLifeline); 554 callRecvFragment.setCovered(msgTargetLifeline); 555 556 // create call 557 Message callMessage = interaction.createMessage(prefix + "call"); 558 callMessage.setSignature(calledOperation); 559 setMessageParameters(callMessage, calledOperation, event, 560 useRandomRequestBodies, prefix); 561 callMessage.setConnector(connector); 562 callMessage.setSendEvent(callSendFragment); 563 callMessage.setReceiveEvent(callRecvFragment); 564 callSendFragment.setMessage(callMessage); 565 callRecvFragment.setMessage(callMessage); 566 567 if (asynch) { 568 // Create ASYNCH call 569 callMessage.setMessageSort(MessageSort.ASYNCH_CALL_LITERAL); 570 } 571 else { 572 // SYNCH call 573 callMessage.setMessageSort(MessageSort.SYNCH_CALL_LITERAL); 574 } 575 } 576 if (!asynch && SOAPUtils.isSOAPResponse(event)) { 577 // setup reply and behavior execution specifications 578 MessageOccurrenceSpecification replySendFragment = 579 (MessageOccurrenceSpecification) interaction 580 .createFragment(prefix + "replySendFragment", 581 UMLPackage.Literals.MESSAGE_OCCURRENCE_SPECIFICATION); 582 MessageOccurrenceSpecification replyRecvFragment = 583 (MessageOccurrenceSpecification) interaction 584 .createFragment(prefix + "replyRecvFragment", 585 UMLPackage.Literals.MESSAGE_OCCURRENCE_SPECIFICATION); 586 587 replySendFragment.setCovered(msgTargetLifeline); 588 replyRecvFragment.setCovered(msgSourceLifeline); 589 590 /* 591 * BehaviorExecutionSpecification sourceBehaviorExecutionSpecification = 592 * (BehaviorExecutionSpecification) interaction .createFragment(":" + methodName 593 * + "_sourceBhvExecSpec", 594 * UMLPackage.Literals.BEHAVIOR_EXECUTION_SPECIFICATION); 595 * BehaviorExecutionSpecification targetBehaviorExecutionSpecification = 596 * (BehaviorExecutionSpecification) interaction .createFragment(":" + methodName 597 * + "_targetBhvExecSpec", 598 * UMLPackage.Literals.BEHAVIOR_EXECUTION_SPECIFICATION); 599 * 600 * sourceBehaviorExecutionSpecification.setStart(callSendFragment); 601 * sourceBehaviorExecutionSpecification.setFinish(replyRecvFragment); 602 * targetBehaviorExecutionSpecification.setStart(callRecvFragment); 603 * targetBehaviorExecutionSpecification.setFinish(replySendFragment); 604 */ 605 606 // create reply 607 Message replyMessage = interaction.createMessage(prefix + "_reply"); 608 replyMessage.setMessageSort(MessageSort.REPLY_LITERAL); 609 replyMessage.setSignature(calledOperation); 610 // setReplyMessageParameters(replyMessage, calledOperation); 611 setMessageParameters(replyMessage, calledOperation, event, 612 useRandomRequestBodies, prefix); 613 replyMessage.setConnector(connector); 614 replyMessage.setSendEvent(replySendFragment); 615 replyMessage.setReceiveEvent(replyRecvFragment); 616 replySendFragment.setMessage(replyMessage); 617 replyRecvFragment.setMessage(replyMessage); 618 } 619 620 i++; 621 } 622 } 623 return interaction; 431 UMLInteractionCreator interactionCreator = new UMLInteractionCreator(model, testContextName, useRandomMsgBodies); 432 return interactionCreator.createInteraction(sequence, interactionName); 624 433 } 625 434 … … 768 577 * @return first matching operation; null if no match is found 769 578 */ 770 p rivatestatic Operation getOperationFromName(EList<Operation> operations, String name) {579 public static Operation getOperationFromName(EList<Operation> operations, String name) { 771 580 if (name == null) { 772 581 throw new IllegalArgumentException("name of the operation must not be null"); … … 837 646 * @return realized interfaces 838 647 */ 839 p rivatestatic Set<Interface> getRealizedInterfacesFromProperty(Property property) {648 public static Set<Interface> getRealizedInterfacesFromProperty(Property property) { 840 649 return getRealizedInterfaceFromComponent((Component) property.getType()); 841 650 } … … 851 660 * @return realized interfaces 852 661 */ 853 p rivatestatic Set<Interface> getRealizedInterfaceFromComponent(Component component) {662 public static Set<Interface> getRealizedInterfaceFromComponent(Component component) { 854 663 Set<Interface> interfaces = new HashSet<>(); 855 664 // Interface myInterface = null; … … 881 690 * @return {@link Component} to which the TestContext stereotype is applied 882 691 */ 883 p rivatestatic Component fetchTestContext(final Package pkg, final String testContextName) {692 public static Component fetchTestContext(final Package pkg, final String testContextName) { 884 693 List<Component> testContexts = fetchAllTestContexts(pkg); 885 694 if (testContexts.isEmpty()) { … … 913 722 * @return {@link List} of test contexts 914 723 */ 915 p rivatestatic List<Component> fetchAllTestContexts(final Package pkg) {724 public static List<Component> fetchAllTestContexts(final Package pkg) { 916 725 final Stereotype utpTestContext = UTPUtils.getTestContextStereotype(pkg.getModel()); 917 726 final List<Component> testContexts = new LinkedList<>(); … … 938 747 * @return properties that represent test components 939 748 */ 940 p rivatestatic Set<Property> fetchAllTestComponentProperties(final Component testContext) {749 public static Set<Property> fetchAllTestComponentProperties(final Component testContext) { 941 750 // fetch all SUTs and TestComponents 942 751 final Stereotype utpTestComponent = … … 960 769 * @return properties that represent the SUTs 961 770 */ 962 p rivatestatic Set<Property> fetchAllSUTProperties(final Component testContext) {771 public static Set<Property> fetchAllSUTProperties(final Component testContext) { 963 772 // fetch all SUTs and TestComponents 964 773 final Stereotype utpSUT = UTPUtils.getSUTStereotype(testContext.getModel()); … … 982 791 * target lifeline of the message 983 792 */ 984 p rivatestatic Connector inferConnector(Lifeline msgSourceLifeline,793 public static Connector inferConnector(Lifeline msgSourceLifeline, 985 794 Lifeline msgTargetLifeline, 986 795 Interface targetInterface) … … 1045 854 } 1046 855 1047 /** 1048 * <p> 1049 * Sets values for the parameters of a call message. The values are, if possible, inferred from 1050 * the event that is provided. 1051 * </p> 1052 * 1053 * @param message 1054 * call message for which the parameters are set 1055 * @param calledOperation 1056 * operation that is called by the message 1057 * @param event 1058 * event that provides the parameters; in case of null, default values are assumed 1059 * @param useRandomMsgBodies 1060 * defines is random request bodies are used or the body of the associated event 1061 * @param prefix 1062 * prefix of the call message; used to create good warnings and debugging information 1063 */ 1064 private static void setMessageParameters(Message message, 1065 Operation calledOperation, 1066 Event event, 1067 boolean useRandomMsgBodies, 1068 String prefix) 1069 { 1070 org.w3c.dom.Element requestBody; 1071 if (SOAPUtils.isSOAPRequest(event)) { 1072 requestBody = 1073 SOAPUtils.getSoapBodyFromEvent(event, useRandomMsgBodies, CallType.REQUEST); 1074 } 1075 else { 1076 requestBody = 1077 SOAPUtils.getSoapBodyFromEvent(event, useRandomMsgBodies, CallType.RESPONSE); 1078 } 1079 Package instSpecPkg = null; 1080 MutableInt instSpecNumber = new MutableInt(0); 1081 1082 // Set parameters of operation 1083 for (Parameter param : calledOperation.getOwnedParameters()) { 1084 if (instSpecPkg == null) { 1085 instSpecPkg = getOrCreateInstanceSpecificationPackage(message.getModel(), event); 1086 } 1087 1088 String path = calledOperation.getName() + ":" + param.getType().getName(); 1089 if ((isInParameter(param) && SOAPUtils.isSOAPRequest(event)) || 1090 (isOutParameter(param) && SOAPUtils.isSOAPResponse(event))) 1091 { 1092 1093 // create parameters node 1094 if (!(param.getType() instanceof DataType)) { 1095 throw new RuntimeException("TODO error handling; parameters missing"); 1096 } 1097 DataType parametersNode = (DataType) param.getType(); 1098 InstanceSpecification instSpecParameters = 1099 (InstanceSpecification) instSpecPkg 1100 .createPackagedElement(prefix + "instspec" + instSpecNumber.intValue() + 1101 "_" + param.getType().getName(), 1102 UMLPackage.Literals.INSTANCE_SPECIFICATION); 1103 instSpecParameters.getClassifiers().add((DataType) param.getType()); 1104 instSpecNumber.setValue(instSpecNumber.intValue() + 1); 1105 InstanceValue instanceValue = 1106 (InstanceValue) message.createArgument(param.getName(), param.getType(), 1107 UMLPackage.Literals.INSTANCE_VALUE); 1108 instanceValue.setInstance(instSpecParameters); 1109 1110 for (Property internalParameter : parametersNode.getAllAttributes()) { 1111 if (internalParameter.getType() instanceof DataType) { 1112 List<org.w3c.dom.Element> paramNodes = 1113 SOAPUtils.getMatchingChildNode(internalParameter.getType().getName(), 1114 requestBody); 1115 int multiplicityChosen = paramNodes.size(); 1116 1117 if (multiplicityChosen == 0 && internalParameter.getLower() > 0) { 1118 Console 1119 .traceln(Level.WARNING, 1120 "required attribute not found in SOAP message: " + path); 1121 Console 1122 .traceln(Level.WARNING, 1123 "setting default values for this attribute and all its children"); 1124 Console.traceln(Level.FINE, "XML structure of path:" + 1125 StringTools.ENDLINE + SOAPUtils.getSerialization(requestBody)); 1126 multiplicityChosen = internalParameter.getLower(); 1127 } 1128 for (int i = 0; i < multiplicityChosen; i++) { 1129 org.w3c.dom.Element paramNode = null; 1130 if (!paramNodes.isEmpty()) { 1131 paramNode = paramNodes.get(i); 1132 } 1133 1134 Slot slot = instSpecParameters.createSlot(); 1135 slot.setDefiningFeature(internalParameter); 1136 1137 InstanceValue value = 1138 (InstanceValue) slot 1139 .createValue(internalParameter.getName() + "_" + i, 1140 internalParameter.getType(), 1141 UMLPackage.Literals.INSTANCE_VALUE); 1142 value 1143 .setInstance(createInstanceSpecification((DataType) internalParameter 1144 .getType(), 1145 instSpecPkg, prefix, 1146 instSpecNumber, paramNode, 1147 path)); 1148 /* 1149 * InstanceValue value = (InstanceValue) argument .createOperand(null, 1150 * internalParameter.getType(), UMLPackage.Literals.INSTANCE_VALUE); 1151 * value.setInstance(instSpec); 1152 */ 1153 } 1154 } 1155 else if (internalParameter.getType() instanceof PrimitiveType) { 1156 createSlotPrimitiveType(instSpecParameters, internalParameter, requestBody, 1157 path); 1158 } 1159 } 1160 } 1161 else { 1162 // set literalNull for out and return parameters 1163 // argument.createOperand(null, param.getType(), UMLPackage.Literals.LITERAL_NULL); 1164 message.createArgument(param.getName(), param.getType(), 1165 UMLPackage.Literals.LITERAL_NULL); 1166 } 1167 } 1168 } 1169 1170 /** 1171 * <p> 1172 * Creates an {@link InstanceSpecification} for a data type in the given package. The values are 1173 * inferred, if possible, from the DOM node. The prefix and the path are used for naming the 1174 * instance specification and to provide good warnings and debug information in case of 1175 * problems. 1176 * </p> 1177 * 1178 * @param type 1179 * DataType for which the {@link InstanceSpecification} is created 1180 * @param pkg 1181 * package in which the {@link InstanceSpecification} is created 1182 * @param prefix 1183 * prefix used for naming the {@link InstanceSpecification} 1184 * @param currentNode 1185 * node of a DOM from which values are inferred 1186 * @param path 1187 * used for warnings and debug information 1188 * @return {@link InstanceSpecification} for the given type 1189 */ 1190 private static InstanceSpecification createInstanceSpecification(DataType type, 1191 Package pkg, 1192 String prefix, 1193 MutableInt instSpecNumber, 1194 org.w3c.dom.Element currentNode, 1195 String path) 1196 { 1197 if ("".equals(path)) { 1198 path = type.getName(); 1199 } 1200 1201 InstanceSpecification instSpec = 1202 (InstanceSpecification) pkg 1203 .createPackagedElement(prefix + "instspec" + instSpecNumber.intValue() + "_" + 1204 type.getName(), 1205 UMLPackage.Literals.INSTANCE_SPECIFICATION); 1206 instSpec.getClassifiers().add(type); 1207 instSpecNumber.setValue(instSpecNumber.intValue() + 1); 1208 for (Property prop : type.getAllAttributes()) { 1209 if (prop.getType() instanceof PrimitiveType) { 1210 createSlotPrimitiveType(instSpec, prop, currentNode, path); 1211 } 1212 else if (prop.getType() instanceof DataType) { 1213 List<org.w3c.dom.Element> attributeNodes = null; 1214 int multiplicityChosen = 0; 1215 if (currentNode != null) { 1216 attributeNodes = SOAPUtils.getMatchingChildNode(prop.getName(), currentNode); 1217 multiplicityChosen = attributeNodes.size(); 1218 } 1219 1220 if (multiplicityChosen == 0 && prop.getLower() > 0) { 1221 if (currentNode != null) { 1222 Console.traceln(Level.WARNING, 1223 "required attribute not found in SOAP message: " + path + 1224 "." + prop.getName()); 1225 Console 1226 .traceln(Level.WARNING, 1227 "setting default values for this attribute and all its children"); 1228 Console.traceln(Level.FINE, "XML structure of path:" + StringTools.ENDLINE + 1229 SOAPUtils.getSerialization(currentNode)); 1230 } 1231 multiplicityChosen = prop.getLower(); 1232 } 1233 for (int i = 0; i < multiplicityChosen; i++) { 1234 org.w3c.dom.Element attributeNode = null; 1235 if (attributeNodes != null && !attributeNodes.isEmpty()) { 1236 attributeNode = attributeNodes.get(i); 1237 } 1238 1239 Slot slot = instSpec.createSlot(); 1240 slot.setDefiningFeature(prop); 1241 1242 InstanceValue value = 1243 (InstanceValue) slot.createValue(prop.getName() + "_" + i, prop.getType(), 1244 UMLPackage.Literals.INSTANCE_VALUE); 1245 value.setInstance(createInstanceSpecification((DataType) prop.getType(), pkg, 1246 prefix, instSpecNumber, 1247 attributeNode, 1248 path + "." + prop.getName())); 1249 } 1250 } 1251 else { 1252 Console.traceln(Level.SEVERE, "property neither DataType nor PrimitiveType: " + 1253 prop.getType()); 1254 throw new RuntimeException("can only handle DataType and PrimitiveType properties but was: " + prop.getType().getClass().getName()); 1255 } 1256 } 1257 return instSpec; 1258 } 1259 1260 /** 1261 * <p> 1262 * Gets or creates a {@link Package} for {@link InstanceSpecification} created by the 1263 * usage-based testing. Each service gets its own sub-package within a package called 1264 * UBT_InstanceSpecifications. " 1265 * </p> 1266 * 1267 * @param model 1268 * model in which the package is generated 1269 * @param event 1270 * event from which the service name is inferred 1271 * @return package for the {@link InstanceSpecification}s 1272 */ 1273 private static Package getOrCreateInstanceSpecificationPackage(Model model, Event event) { 1274 String pkgUBTInstSpecs = "UBT_InstanceSpecifications"; 1275 Package ubtInstSpecPkg = (Package) model.getOwnedMember(pkgUBTInstSpecs); 1276 if (ubtInstSpecPkg == null) { 1277 ubtInstSpecPkg = 1278 (Package) model.createPackagedElement(pkgUBTInstSpecs, UMLPackage.Literals.PACKAGE); 1279 } 1280 String serviceName = SOAPUtils.getServiceNameFromEvent(event); 1281 Package serviceInstSpecPkg = (Package) ubtInstSpecPkg.getOwnedMember(serviceName); 1282 if (serviceInstSpecPkg == null) { 1283 serviceInstSpecPkg = 1284 (Package) ubtInstSpecPkg.createPackagedElement(serviceName, 1285 UMLPackage.Literals.PACKAGE); 1286 } 1287 return serviceInstSpecPkg; 1288 } 856 1289 857 1290 858 /** … … 1381 949 } 1382 950 1383 /** 1384 * <p> 1385 * Creates a {@link Slot} in an {@link InstanceSpecification} for a primitive type. 1386 * </p> 1387 * 1388 * @param instSpec 1389 * instance specification to which the slot is added 1390 * @param prop 1391 * property that describes the slot 1392 * @param currentNode 1393 * DOM node from which is value for the slot is inferred 1394 * @param path 1395 * used for warnings and debug information 1396 */ 1397 private static void createSlotPrimitiveType(InstanceSpecification instSpec, 1398 Property prop, 1399 org.w3c.dom.Element currentNode, 1400 String path) 1401 { 1402 List<String> attributeValues = SOAPUtils.getValuesFromElement(prop.getName(), currentNode); 1403 1404 if (attributeValues.isEmpty()) { 1405 if (prop.getLower() == 0) { 1406 // ignoring optional attribute 1407 return; 1408 } 1409 else { 1410 if (currentNode != null) { 1411 Console.traceln(Level.WARNING, 1412 "required attribute not found in SOAP message: " + path + "." + 1413 prop.getName()); 1414 Console.traceln(Level.WARNING, "setting default values for this attribute"); 1415 Console.traceln(Level.FINE, "XML structure of path:" + StringTools.ENDLINE + 1416 SOAPUtils.getSerialization(currentNode)); 1417 } 1418 attributeValues.add(null); 1419 } 1420 } 1421 for (String attributeValue : attributeValues) { 1422 Slot slot = instSpec.createSlot(); 1423 slot.setDefiningFeature(prop); 1424 if ("String".equals(prop.getType().getName())) { 1425 LiteralString value = 1426 (LiteralString) slot.createValue(prop.getName(), null, 1427 UMLPackage.Literals.LITERAL_STRING); 1428 if (attributeValue != null) { 1429 value.setValue(attributeValue); 1430 } 1431 else { 1432 value.setValue("foobar"); 1433 } 1434 } 1435 else if ("Integer".equals(prop.getType().getName())) { 1436 LiteralInteger value = 1437 (LiteralInteger) slot.createValue(prop.getName(), null, 1438 UMLPackage.Literals.LITERAL_INTEGER); 1439 if (attributeValue != null) { 1440 value.setValue(Integer.parseInt(attributeValue)); 1441 } 1442 else { 1443 value.setValue(42); 1444 } 1445 } 1446 else if ("Boolean".equals(prop.getType().getName())) { 1447 LiteralBoolean value = 1448 (LiteralBoolean) slot.createValue(prop.getName(), null, 1449 UMLPackage.Literals.LITERAL_BOOLEAN); 1450 if (attributeValue != null) { 1451 value.setValue(Boolean.parseBoolean(attributeValue)); 1452 } 1453 else { 1454 value.setValue(true); 1455 } 1456 } 1457 else if ("Real".equals(prop.getType().getName())) { 1458 LiteralReal value = 1459 (LiteralReal) slot.createValue(prop.getName(), null, 1460 UMLPackage.Literals.LITERAL_REAL); 1461 if (attributeValue != null) { 1462 value.setValue(Double.parseDouble(attributeValue)); 1463 } 1464 else { 1465 value.setValue(3.14); 1466 } 1467 } 1468 else { 1469 Console.traceln(Level.SEVERE, "could not create literal for primitive type: " + 1470 prop.getType().getName()); 1471 throw new RuntimeException("unknown primitive type: " + prop.getType().getName()); 1472 } 1473 } 1474 } 951 1475 952 1476 953 /** … … 1483 960 * @return true if the direction is IN or INOUT; false otherwise 1484 961 */ 1485 p rivatestatic boolean isInParameter(Parameter parameter) {962 public static boolean isInParameter(Parameter parameter) { 1486 963 return parameter.getDirection() == ParameterDirectionKind.IN_LITERAL || 1487 964 parameter.getDirection() == ParameterDirectionKind.INOUT_LITERAL; … … 1497 974 * @return true if the direction is RETURN, OUT, or INOUT; false otherwise 1498 975 */ 1499 p rivatestatic boolean isOutParameter(Parameter parameter) {976 public static boolean isOutParameter(Parameter parameter) { 1500 977 return parameter.getDirection() == ParameterDirectionKind.RETURN_LITERAL || 1501 978 parameter.getDirection() == ParameterDirectionKind.OUT_LITERAL || … … 1513 990 * @return true if the message is a call message; false otherwise 1514 991 */ 1515 p rivatestatic boolean isCallMessage(Message message) {992 public static boolean isCallMessage(Message message) { 1516 993 if (message == null) { 1517 994 return false;
Note: See TracChangeset
for help on using the changeset viewer.