|
49 | 49 | import org.eclipse.syson.application.controller.explorer.testers.ExpandAllTreeItemTester; |
50 | 50 | import org.eclipse.syson.application.controller.explorer.testers.TreeItemContextMenuTester; |
51 | 51 | import org.eclipse.syson.application.controller.explorer.testers.TreePathTester; |
| 52 | +import org.eclipse.syson.application.data.ActionTransitionUsagesProjectData; |
52 | 53 | import org.eclipse.syson.application.data.GeneralViewEmptyTestProjectData; |
53 | 54 | import org.eclipse.syson.application.data.ProjectWithLibraryDependencyContainingCommentAndLibraryPackageTestProjectData; |
54 | 55 | import org.eclipse.syson.application.data.ProjectWithLibraryDependencyContainingLibraryPackageTestProjectData; |
@@ -871,4 +872,70 @@ public void sysONExplorerTreeItemContextMenuEntriesTest() { |
871 | 872 | .verify(Duration.ofSeconds(10)); |
872 | 873 |
|
873 | 874 | } |
| 875 | + |
| 876 | + @DisplayName("GIVEN the SysON Explorer, WHEN displaying an Expression item, THEN the item's label shows the textual representation of the expression") |
| 877 | + @Sql(scripts = { ActionTransitionUsagesProjectData.SCRIPT_PATH }, executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD, config = @SqlConfig(transactionMode = SqlConfig.TransactionMode.ISOLATED)) |
| 878 | + @Sql(scripts = { "/scripts/cleanup.sql" }, executionPhase = Sql.ExecutionPhase.AFTER_TEST_METHOD, config = @SqlConfig(transactionMode = SqlConfig.TransactionMode.ISOLATED)) |
| 879 | + @Test |
| 880 | + public void sysONExplorerTreeExpressionLabelTest() { |
| 881 | + |
| 882 | + var optionalEditingContext = this.editingContextSearchService.findById(ActionTransitionUsagesProjectData.EDITING_CONTEXT_ID); |
| 883 | + TreeDescription treeDescription = optionalEditingContext |
| 884 | + .flatMap(editingContext -> this.representationDescriptionSearchService.findById(editingContext, this.sysONExplorerTreeDescriptionId)) |
| 885 | + .filter(TreeDescription.class::isInstance) |
| 886 | + .map(TreeDescription.class::cast) |
| 887 | + .orElse(null); |
| 888 | + List<String> defaultFilters = this.sysonTreeFilterProvider.get(null, treeDescription).stream() |
| 889 | + .filter(TreeFilter::defaultState) |
| 890 | + .map(TreeFilter::id) |
| 891 | + .toList(); |
| 892 | + |
| 893 | + var expandedItemIds = List.of( |
| 894 | + ActionTransitionUsagesProjectData.SemanticIds.DOCUMENT_ID, |
| 895 | + ActionTransitionUsagesProjectData.SemanticIds.PACKAGE_1_ID, |
| 896 | + ActionTransitionUsagesProjectData.SemanticIds.A0_ID, |
| 897 | + ActionTransitionUsagesProjectData.SemanticIds.S1_ID, |
| 898 | + ActionTransitionUsagesProjectData.SemanticIds.S2_ID); |
| 899 | + |
| 900 | + var explorerRepresentationId = this.representationIdBuilder.buildExplorerRepresentationId(this.sysONExplorerTreeDescriptionId, expandedItemIds, defaultFilters); |
| 901 | + var input = new ExplorerEventInput(UUID.randomUUID(), ActionTransitionUsagesProjectData.EDITING_CONTEXT_ID, explorerRepresentationId); |
| 902 | + var flux = this.explorerEventSubscriptionRunner.run(input).flux(); |
| 903 | + TestTransaction.flagForCommit(); |
| 904 | + TestTransaction.end(); |
| 905 | + |
| 906 | + var treeId = new AtomicReference<String>(); |
| 907 | + Consumer<Object> initialTreeContentConsumer = assertRefreshedTreeThat(tree -> { |
| 908 | + assertThat(tree).isNotNull(); |
| 909 | + treeId.set(tree.getId()); |
| 910 | + assertThat(tree.getChildren()).hasSize(2); |
| 911 | + var documentItem = tree.getChildren().get(0); |
| 912 | + assertThat(documentItem.getChildren()).hasSize(1); |
| 913 | + assertThat(documentItem.getLabel().toString()).isEqualTo("ActionTransitionUsage.sysml"); |
| 914 | + var packageItem = documentItem.getChildren().get(0); |
| 915 | + assertThat(packageItem.getLabel().toString()).isEqualTo("Package 1"); |
| 916 | + assertThat(packageItem.getChildren()).hasSize(3); |
| 917 | + var a0Item = packageItem.getChildren().get(0); |
| 918 | + assertThat(a0Item.getLabel().toString()).isEqualTo("a0"); |
| 919 | + assertThat(a0Item.getChildren()).hasSize(7); |
| 920 | + var s1Item = a0Item.getChildren().get(5); |
| 921 | + assertThat(s1Item.getLabel().toString()).isEqualTo("S1"); |
| 922 | + assertThat(s1Item.getChildren()).hasSize(3); |
| 923 | + var expr1Item = s1Item.getChildren().get(0); |
| 924 | + assertThat(expr1Item.getKind()).isEqualTo("siriusComponents://semantic?domain=sysml&entity=OperatorExpression"); |
| 925 | + assertThat(expr1Item.getLabel().toString()).isEqualTo("attr1 < 1"); |
| 926 | + |
| 927 | + var s2Item = a0Item.getChildren().get(6); |
| 928 | + assertThat(s2Item.getLabel().toString()).isEqualTo("S2"); |
| 929 | + assertThat(s2Item.getChildren()).hasSize(3); |
| 930 | + var expr2Item = s2Item.getChildren().get(0); |
| 931 | + assertThat(expr2Item.getKind()).isEqualTo("siriusComponents://semantic?domain=sysml&entity=OperatorExpression"); |
| 932 | + assertThat(expr2Item.getLabel().toString()).isEqualTo("attr1 < 0"); |
| 933 | + |
| 934 | + }); |
| 935 | + |
| 936 | + StepVerifier.create(flux) |
| 937 | + .consumeNextWith(initialTreeContentConsumer) |
| 938 | + .thenCancel() |
| 939 | + .verify(Duration.ofSeconds(10_000)); |
| 940 | + } |
874 | 941 | } |
0 commit comments