aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java2
-rw-r--r--sonar-db/src/test/java/org/sonar/db/component/ResourceTypesRule.java5
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/resources/ResourceTypes.java34
-rw-r--r--sonar-plugin-api/src/test/java/org/sonar/api/resources/ResourceTypesTest.java9
4 files changed, 43 insertions, 7 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java b/server/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
index 1ac5edd05ec..8f4e7a0b87c 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
@@ -93,7 +93,7 @@ public final class JRubyFacade {
}
public Collection<ResourceType> getResourceTypes() {
- return get(ResourceTypes.class).getAll();
+ return get(ResourceTypes.class).getAllOrdered();
}
public Collection<ResourceType> getResourceRootTypes() {
diff --git a/sonar-db/src/test/java/org/sonar/db/component/ResourceTypesRule.java b/sonar-db/src/test/java/org/sonar/db/component/ResourceTypesRule.java
index 01e386f91ad..8f56a0e5192 100644
--- a/sonar-db/src/test/java/org/sonar/db/component/ResourceTypesRule.java
+++ b/sonar-db/src/test/java/org/sonar/db/component/ResourceTypesRule.java
@@ -44,6 +44,11 @@ public class ResourceTypesRule extends ResourceTypes {
}
@Override
+ public Collection<ResourceType> getAllOrdered() {
+ return allResourceTypes;
+ }
+
+ @Override
public Collection<ResourceType> getRoots() {
return rootResourceTypes;
}
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/resources/ResourceTypes.java b/sonar-plugin-api/src/main/java/org/sonar/api/resources/ResourceTypes.java
index bc1cbbd4120..02beeab6ede 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/resources/ResourceTypes.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/resources/ResourceTypes.java
@@ -27,17 +27,17 @@ import com.google.common.base.Predicate;
import com.google.common.collect.Collections2;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.google.common.collect.Sets;
-import org.sonar.api.server.ServerSide;
-
-import javax.annotation.Nullable;
-
+import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Map;
+import javax.annotation.Nullable;
+import org.sonar.api.server.ServerSide;
/**
* @since 2.14
@@ -55,6 +55,7 @@ public class ResourceTypes {
private final Map<String, ResourceTypeTree> treeByQualifier;
private final Map<String, ResourceType> typeByQualifier;
+ private final Collection<ResourceType> orderedTypes;
private final Collection<ResourceType> rootTypes;
public ResourceTypes() {
@@ -81,6 +82,27 @@ public class ResourceTypes {
treeByQualifier = ImmutableMap.copyOf(treeMap);
typeByQualifier = ImmutableMap.copyOf(typeMap);
rootTypes = ImmutableList.copyOf(rootsSet);
+
+ List<ResourceType> mutableOrderedTypes = new ArrayList<>();
+ ResourceType view = null;
+ ResourceType subView = null;
+ for (ResourceType resourceType : typeByQualifier.values()) {
+ if (Qualifiers.VIEW.equals(resourceType.getQualifier())) {
+ view = resourceType;
+ } else if (Qualifiers.SUBVIEW.equals(resourceType.getQualifier())) {
+ subView = resourceType;
+ } else {
+ mutableOrderedTypes.add(resourceType);
+ }
+ }
+ if (subView != null) {
+ mutableOrderedTypes.add(0, subView);
+ }
+ if (view != null) {
+ mutableOrderedTypes.add(0, view);
+ }
+
+ orderedTypes = ImmutableSet.copyOf(mutableOrderedTypes);
}
public ResourceType get(String qualifier) {
@@ -92,6 +114,10 @@ public class ResourceTypes {
return typeByQualifier.values();
}
+ public Collection<ResourceType> getAllOrdered() {
+ return orderedTypes;
+ }
+
public Collection<ResourceType> getRoots() {
return rootTypes;
}
diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/resources/ResourceTypesTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/resources/ResourceTypesTest.java
index 5efd1952a1c..0998acf43f9 100644
--- a/sonar-plugin-api/src/test/java/org/sonar/api/resources/ResourceTypesTest.java
+++ b/sonar-plugin-api/src/test/java/org/sonar/api/resources/ResourceTypesTest.java
@@ -44,7 +44,7 @@ public class ResourceTypesTest {
.addRelations(Qualifiers.DIRECTORY, Qualifiers.FILE)
.build();
- private ResourceTypes types = new ResourceTypes(new ResourceTypeTree[] {viewsTree, defaultTree});
+ private ResourceTypes types = new ResourceTypes(new ResourceTypeTree[] {defaultTree, viewsTree});
@Test
public void get() {
@@ -56,7 +56,12 @@ public class ResourceTypesTest {
@Test
public void get_all() {
- assertThat(qualifiers(types.getAll())).containsOnly(Qualifiers.PROJECT, Qualifiers.DIRECTORY, Qualifiers.FILE, Qualifiers.VIEW, Qualifiers.SUBVIEW);
+ assertThat(qualifiers(types.getAll())).containsExactly(Qualifiers.PROJECT, Qualifiers.DIRECTORY, Qualifiers.FILE, Qualifiers.VIEW, Qualifiers.SUBVIEW);
+ }
+
+ @Test
+ public void get_all_ordered() {
+ assertThat(qualifiers(types.getAllOrdered())).containsExactly(Qualifiers.VIEW, Qualifiers.SUBVIEW, Qualifiers.PROJECT, Qualifiers.DIRECTORY, Qualifiers.FILE);
}
@Test