|
47 | 47 | import org.eclipse.syson.application.controller.explorer.testers.TreeItemContextMenuTester; |
48 | 48 | import org.eclipse.syson.application.controller.explorer.testers.TreePathTester; |
49 | 49 | import org.eclipse.syson.application.data.ActionTransitionUsagesProjectData; |
| 50 | +import org.eclipse.syson.application.data.ExpressionSamplesProjectData; |
50 | 51 | import org.eclipse.syson.application.data.GeneralViewEmptyTestProjectData; |
51 | 52 | import org.eclipse.syson.application.data.ProjectWithLibraryDependencyContainingCommentAndLibraryPackageTestProjectData; |
52 | 53 | import org.eclipse.syson.application.data.ProjectWithLibraryDependencyContainingLibraryPackageTestProjectData; |
@@ -871,4 +872,128 @@ public void sysONExplorerTreeExpressionLabelTest() { |
871 | 872 | .thenCancel() |
872 | 873 | .verify(Duration.ofSeconds(10)); |
873 | 874 | } |
| 875 | + |
| 876 | + @DisplayName("GIVEN the SysON Explorer, WHEN displaying an Expression item, THEN its internal details are hidden by default") |
| 877 | + @GivenSysONServer({ ExpressionSamplesProjectData.SCRIPT_PATH }) |
| 878 | + @Test |
| 879 | + public void sysONExplorerHidesExpressionInternalsByDefault() { |
| 880 | + List<String> defaultFilters = this.explorerDefaultFiltersSearchService.findTreeDefaultFilterIds(ExpressionSamplesProjectData.EDITING_CONTEXT_ID, this.sysONExplorerTreeDescriptionId); |
| 881 | + |
| 882 | + var expandedItemIds = List.of( |
| 883 | + ExpressionSamplesProjectData.SemanticIds.EXPRESSIONS_DOCUMENT_ID, |
| 884 | + ExpressionSamplesProjectData.SemanticIds.EXPRESSIONS_PACKAGE_ID, |
| 885 | + ExpressionSamplesProjectData.SemanticIds.TANK_ID, |
| 886 | + ExpressionSamplesProjectData.SemanticIds.TANK_MAX_VOLUME_ATTRIBUTE_ID, |
| 887 | + ExpressionSamplesProjectData.SemanticIds.TANK_MAX_VOLUME_ATTRIBUTE_VALUE_ID, |
| 888 | + ExpressionSamplesProjectData.SemanticIds.TANK_PRESSURE_LIMIT_CONSTRAINT_ID, |
| 889 | + ExpressionSamplesProjectData.SemanticIds.TANK_PRESSURE_LIMIT_CONSTRAINT_VALUE_ID); |
| 890 | + |
| 891 | + var explorerRepresentationId = this.representationIdBuilder.buildExplorerRepresentationId(this.sysONExplorerTreeDescriptionId, expandedItemIds, defaultFilters); |
| 892 | + var input = new ExplorerEventInput(UUID.randomUUID(), ExpressionSamplesProjectData.EDITING_CONTEXT_ID, explorerRepresentationId); |
| 893 | + var flux = this.explorerEventSubscriptionRunner.run(input).flux(); |
| 894 | + TestTransaction.flagForCommit(); |
| 895 | + TestTransaction.end(); |
| 896 | + |
| 897 | + var treeId = new AtomicReference<String>(); |
| 898 | + Consumer<Object> initialTreeContentConsumer = assertRefreshedTreeThat(tree -> { |
| 899 | + assertThat(tree).isNotNull(); |
| 900 | + treeId.set(tree.getId()); |
| 901 | + assertThat(tree.getChildren()).hasSize(2); |
| 902 | + var documentItem = tree.getChildren().get(0); |
| 903 | + assertThat(documentItem.getChildren()).hasSize(1); |
| 904 | + assertThat(documentItem.getLabel().toString()).isEqualTo("expressions.sysml"); |
| 905 | + var packageItem = documentItem.getChildren().get(0); |
| 906 | + assertThat(packageItem.getLabel().toString()).isEqualTo("Expressions"); |
| 907 | + |
| 908 | + assertThat(packageItem.getChildren()).hasSize(7); |
| 909 | + |
| 910 | + var tankItem = this.getChildByLabel(packageItem, "Tank"); |
| 911 | + assertThat(tankItem).isPresent(); |
| 912 | + |
| 913 | + var maxVolumeAttribute = this.getChildByLabel(tankItem.get(), "maxVolume"); |
| 914 | + assertThat(maxVolumeAttribute).isPresent(); |
| 915 | + assertThat(maxVolumeAttribute.get().getChildren()).hasSize(2); |
| 916 | + var maxVolumeAttributeValueItem = maxVolumeAttribute.get().getChildren().get(0); |
| 917 | + assertThat(maxVolumeAttributeValueItem.getLabel().toString()).isEqualTo("100.0 * minVolume"); |
| 918 | + assertThat(maxVolumeAttributeValueItem.getChildren()).isEmpty(); // Details filtered out by default |
| 919 | + |
| 920 | + var pressureLimitAttribute = this.getChildByLabel(tankItem.get(), "pressureLimit"); |
| 921 | + assertThat(pressureLimitAttribute).isPresent(); |
| 922 | + assertThat(pressureLimitAttribute.get().getChildren()).hasSize(1); |
| 923 | + var pressureLimitAttributeValueItem = pressureLimitAttribute.get().getChildren().get(0); |
| 924 | + assertThat(pressureLimitAttributeValueItem.getLabel().toString()).isEqualTo("pressure <= maxPressure"); |
| 925 | + assertThat(pressureLimitAttributeValueItem.getChildren()).isEmpty(); // Details filtered out by default |
| 926 | + |
| 927 | + }); |
| 928 | + |
| 929 | + StepVerifier.create(flux) |
| 930 | + .consumeNextWith(initialTreeContentConsumer) |
| 931 | + .thenCancel() |
| 932 | + .verify(Duration.ofSeconds(10)); |
| 933 | + } |
| 934 | + |
| 935 | + @DisplayName("GIVEN the SysON Explorer, WHEN displaying an Expression item, THEN its internal details can be revealed by disabling the corresponding filter") |
| 936 | + @GivenSysONServer({ ExpressionSamplesProjectData.SCRIPT_PATH }) |
| 937 | + @Test |
| 938 | + public void sysONExplorerExpressionInternalsCanBeRevealed() { |
| 939 | + List<String> defaultFilters = this.explorerDefaultFiltersSearchService.findTreeDefaultFilterIds(ExpressionSamplesProjectData.EDITING_CONTEXT_ID, this.sysONExplorerTreeDescriptionId); |
| 940 | + // Keep all defaults but HIDE_EXPRESSION_INTERNALS_ID |
| 941 | + List<String> activeFilters = defaultFilters.stream().filter(filterId -> !SysONTreeFilterConstants.HIDE_EXPRESSION_INTERNALS_ID.equals(filterId)).toList(); |
| 942 | + |
| 943 | + var expandedItemIds = List.of( |
| 944 | + ExpressionSamplesProjectData.SemanticIds.EXPRESSIONS_DOCUMENT_ID, |
| 945 | + ExpressionSamplesProjectData.SemanticIds.EXPRESSIONS_PACKAGE_ID, |
| 946 | + ExpressionSamplesProjectData.SemanticIds.TANK_ID, |
| 947 | + ExpressionSamplesProjectData.SemanticIds.TANK_MAX_VOLUME_ATTRIBUTE_ID, |
| 948 | + ExpressionSamplesProjectData.SemanticIds.TANK_MAX_VOLUME_ATTRIBUTE_VALUE_ID, |
| 949 | + ExpressionSamplesProjectData.SemanticIds.TANK_PRESSURE_LIMIT_CONSTRAINT_ID, |
| 950 | + ExpressionSamplesProjectData.SemanticIds.TANK_PRESSURE_LIMIT_CONSTRAINT_VALUE_ID); |
| 951 | + |
| 952 | + var explorerRepresentationId = this.representationIdBuilder.buildExplorerRepresentationId(this.sysONExplorerTreeDescriptionId, expandedItemIds, activeFilters); |
| 953 | + var input = new ExplorerEventInput(UUID.randomUUID(), ExpressionSamplesProjectData.EDITING_CONTEXT_ID, explorerRepresentationId); |
| 954 | + var flux = this.explorerEventSubscriptionRunner.run(input).flux(); |
| 955 | + TestTransaction.flagForCommit(); |
| 956 | + TestTransaction.end(); |
| 957 | + |
| 958 | + var treeId = new AtomicReference<String>(); |
| 959 | + Consumer<Object> initialTreeContentConsumer = assertRefreshedTreeThat(tree -> { |
| 960 | + assertThat(tree).isNotNull(); |
| 961 | + treeId.set(tree.getId()); |
| 962 | + assertThat(tree.getChildren()).hasSize(2); |
| 963 | + var documentItem = tree.getChildren().get(0); |
| 964 | + assertThat(documentItem.getChildren()).hasSize(1); |
| 965 | + assertThat(documentItem.getLabel().toString()).isEqualTo("expressions.sysml"); |
| 966 | + var packageItem = documentItem.getChildren().get(0); |
| 967 | + assertThat(packageItem.getLabel().toString()).isEqualTo("Expressions"); |
| 968 | + |
| 969 | + assertThat(packageItem.getChildren()).hasSize(7); |
| 970 | + |
| 971 | + var tankItem = this.getChildByLabel(packageItem, "Tank"); |
| 972 | + assertThat(tankItem).isPresent(); |
| 973 | + |
| 974 | + var maxVolumeAttribute = this.getChildByLabel(tankItem.get(), "maxVolume"); |
| 975 | + assertThat(maxVolumeAttribute).isPresent(); |
| 976 | + assertThat(maxVolumeAttribute.get().getChildren()).hasSize(2); |
| 977 | + var maxVolumeAttributeValueItem = maxVolumeAttribute.get().getChildren().get(0); |
| 978 | + assertThat(maxVolumeAttributeValueItem.getLabel().toString()).isEqualTo("100.0 * minVolume"); |
| 979 | + assertThat(maxVolumeAttributeValueItem.getChildren()).hasSize(2); // Details visible |
| 980 | + |
| 981 | + var pressureLimitAttribute = this.getChildByLabel(tankItem.get(), "pressureLimit"); |
| 982 | + assertThat(pressureLimitAttribute).isPresent(); |
| 983 | + assertThat(pressureLimitAttribute.get().getChildren()).hasSize(1); |
| 984 | + var pressureLimitAttributeValueItem = pressureLimitAttribute.get().getChildren().get(0); |
| 985 | + assertThat(pressureLimitAttributeValueItem.getLabel().toString()).isEqualTo("pressure <= maxPressure"); |
| 986 | + assertThat(pressureLimitAttributeValueItem.getChildren()).hasSize(2); // Details visible |
| 987 | + |
| 988 | + }); |
| 989 | + |
| 990 | + StepVerifier.create(flux) |
| 991 | + .consumeNextWith(initialTreeContentConsumer) |
| 992 | + .thenCancel() |
| 993 | + .verify(Duration.ofSeconds(10)); |
| 994 | + } |
| 995 | + |
| 996 | + private Optional<TreeItem> getChildByLabel(TreeItem parent, String label) { |
| 997 | + return parent.getChildren().stream().filter(child -> child.getLabel().toString().equals(label)).findFirst(); |
| 998 | + } |
874 | 999 | } |
0 commit comments