aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java6
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/issue/IssueStorage.java3
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/ws/SearchAction.java6
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/index/PermissionIndexerDao.java21
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/project/ws/IndexAction.java8
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/qualitygate/QgateProjectFinder.java6
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/component/ws/SearchActionTest.java18
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/measure/ws/SearchActionTest.java53
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/permission/index/PermissionIndexerDaoTest.java37
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/project/ws/IndexActionTest.java23
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/qualitygate/QgateProjectFinderTest.java16
-rwxr-xr-xtravis.sh22
12 files changed, 159 insertions, 60 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
index 79d794ca6b5..d9a9dd48a01 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
@@ -160,6 +160,12 @@ public class SearchAction implements ComponentsWsAction {
}
private List<ComponentDto> filterAuthorizedComponents(DbSession dbSession, List<ComponentDto> componentDtos) {
+ if (userSession.isRoot()) {
+ // the method AuthorizationDao#keepAuthorizedProjectIds() should be replaced by
+ // a call to UserSession, which would transparently support roots.
+ // Meanwhile root is explicitly handled.
+ return componentDtos;
+ }
Set<String> projectUuids = componentDtos.stream().map(ComponentDto::projectUuid).collect(Collectors.toSet());
List<ComponentDto> projects = dbClient.componentDao().selectByUuids(dbSession, projectUuids);
Map<String, Long> projectIdsByUuids = projects.stream().collect(uniqueIndex(ComponentDto::uuid, ComponentDto::getId));
diff --git a/server/sonar-server/src/main/java/org/sonar/server/issue/IssueStorage.java b/server/sonar-server/src/main/java/org/sonar/server/issue/IssueStorage.java
index 199d8a6d673..1aacf9eb27c 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/issue/IssueStorage.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/issue/IssueStorage.java
@@ -100,10 +100,11 @@ public abstract class IssueStorage {
if (issue.isNew()) {
doInsert(session, now, issue);
insertChanges(issueChangeMapper, issue);
+ count++;
if (count > BatchSession.MAX_BATCH_SIZE) {
session.commit();
+ count = 0;
}
- count++;
} else if (issue.isChanged()) {
toBeUpdated.add(issue);
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SearchAction.java
index 5b52b1cff15..d6be0710a10 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SearchAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SearchAction.java
@@ -137,6 +137,12 @@ public class SearchAction implements MeasuresWsAction {
}
private List<ComponentDto> getAuthorizedProjects(List<ComponentDto> projectDtos) {
+ if (userSession.isRoot()) {
+ // the method AuthorizationDao#keepAuthorizedProjectIds() should be replaced by
+ // a call to UserSession, which would transparently support roots.
+ // Meanwhile root is explicitly handled.
+ return projectDtos;
+ }
Map<String, Long> projectIdsByUuids = projectDtos.stream().collect(uniqueIndex(ComponentDto::uuid, ComponentDto::getId));
Set<Long> authorizedProjectIds = dbClient.authorizationDao().keepAuthorizedProjectIds(dbSession,
projectDtos.stream().map(ComponentDto::getId).collect(toList()),
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/index/PermissionIndexerDao.java b/server/sonar-server/src/main/java/org/sonar/server/permission/index/PermissionIndexerDao.java
index a98674b4fba..e2125d43539 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/index/PermissionIndexerDao.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/permission/index/PermissionIndexerDao.java
@@ -96,10 +96,10 @@ public class PermissionIndexerDao {
/**
* Number of "{projectsCondition}" in SQL template
*/
- private static final int NB_OF_CONDITION_PLACEHOLDERS = 3;
+ private static final int NB_OF_CONDITION_PLACEHOLDERS = 4;
private enum RowKind {
- USER, GROUP, ANYONE
+ USER, GROUP, ANYONE, NONE
}
private static final String SQL_TEMPLATE = "SELECT " +
@@ -160,6 +160,21 @@ public class PermissionIndexerDao {
" AND projects.copy_component_uuid is NULL " +
" {projectsCondition} " +
" AND group_roles.group_id IS NULL " +
+ " UNION " +
+
+ // project is returned when no authorization
+ " SELECT '" + RowKind.NONE + "' as kind," +
+ " projects.uuid AS project, " +
+ " projects.authorization_updated_at AS updated_at, " +
+ " projects.qualifier AS qualifier, " +
+ " NULL AS user_id, " +
+ " NULL AS group_id " +
+ " FROM projects " +
+ " WHERE " +
+ " (projects.qualifier = 'TRK' or projects.qualifier = 'VW') " +
+ " AND projects.copy_component_uuid is NULL " +
+ " {projectsCondition} " +
+
" ) project_authorization";
List<Dto> selectAll(DbClient dbClient, DbSession session) {
@@ -221,6 +236,8 @@ public class PermissionIndexerDao {
dtosByProjectUuid.put(projectUuid, dto);
}
switch (rowKind) {
+ case NONE:
+ break;
case USER:
dto.addUserId(rs.getInt(3));
break;
diff --git a/server/sonar-server/src/main/java/org/sonar/server/project/ws/IndexAction.java b/server/sonar-server/src/main/java/org/sonar/server/project/ws/IndexAction.java
index fce6f300d91..9a2f3a6fc76 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/project/ws/IndexAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/project/ws/IndexAction.java
@@ -22,7 +22,6 @@ package org.sonar.server.project.ws;
import com.google.common.io.Resources;
import java.util.ArrayList;
import java.util.Collection;
-import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Optional;
@@ -134,8 +133,11 @@ public class IndexAction implements ProjectsWsAction {
}
private List<ComponentDto> getAuthorizedComponents(DbSession dbSession, List<ComponentDto> components) {
- if (components.isEmpty()) {
- return Collections.emptyList();
+ if (userSession.isRoot() || components.isEmpty()) {
+ // the method AuthorizationDao#keepAuthorizedProjectIds() should be replaced by
+ // a call to UserSession, which would transparently support roots.
+ // Meanwhile root is explicitly handled.
+ return components;
}
Set<String> projectUuids = components.stream().map(ComponentDto::projectUuid).collect(Collectors.toSet());
List<ComponentDto> projects = dbClient.componentDao().selectByUuids(dbSession, projectUuids);
diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualitygate/QgateProjectFinder.java b/server/sonar-server/src/main/java/org/sonar/server/qualitygate/QgateProjectFinder.java
index b84860fe2c9..646c9890534 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/qualitygate/QgateProjectFinder.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/qualitygate/QgateProjectFinder.java
@@ -81,6 +81,12 @@ public class QgateProjectFinder {
}
private List<ProjectQgateAssociationDto> keepAuthorizedProjects(DbSession dbSession, List<ProjectQgateAssociationDto> projects) {
+ if (userSession.isRoot()) {
+ // the method AuthorizationDao#keepAuthorizedProjectIds() should be replaced by
+ // a call to UserSession, which would transparently support roots.
+ // Meanwhile root is explicitly handled.
+ return projects;
+ }
List<Long> projectIds = projects.stream().map(ProjectQgateAssociationDto::getId).collect(Collectors.toList());
Collection<Long> authorizedProjectIds = dbClient.authorizationDao().keepAuthorizedProjectIds(dbSession, projectIds, userSession.getUserId(), UserRole.USER);
return projects.stream().filter(project -> authorizedProjectIds.contains(project.getId())).collect(Collectors.toList());
diff --git a/server/sonar-server/src/test/java/org/sonar/server/component/ws/SearchActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/component/ws/SearchActionTest.java
index f12883ad9d5..5f8bae83caf 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/component/ws/SearchActionTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/component/ws/SearchActionTest.java
@@ -187,6 +187,24 @@ public class SearchActionTest {
}
@Test
+ public void do_not_verify_permissions_if_user_is_root() throws IOException {
+ OrganizationDto org = db.organizations().insert();
+ ComponentDto project1 = newProjectDto(org);
+ ComponentDto file1 = newFileDto(project1);
+ ComponentDto project2 = newProjectDto(org);
+ ComponentDto file2 = newFileDto(project2);
+ db.components().insertComponents(project1, file1, project2, file2);
+
+ SearchWsRequest request = new SearchWsRequest().setQualifiers(singletonList(FILE)).setOrganization(org.getKey());
+
+ userSession.logIn().setNonRoot();
+ assertThat(call(request).getComponentsCount()).isZero();
+
+ userSession.logIn().setRoot();
+ assertThat(call(request).getComponentsList()).extracting(Component::getKey).containsOnly(file1.getKey(), file2.getKey());
+ }
+
+ @Test
public void fail_if_unknown_qualifier_provided() {
expectedException.expect(IllegalArgumentException.class);
expectedException.expectMessage("Value of parameter 'qualifiers' (Unknown-Qualifier) must be one of: [BRC, DIR, FIL, TRK]");
diff --git a/server/sonar-server/src/test/java/org/sonar/server/measure/ws/SearchActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/measure/ws/SearchActionTest.java
index 76f81f68c7d..120da09a887 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/measure/ws/SearchActionTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/measure/ws/SearchActionTest.java
@@ -38,7 +38,6 @@ import org.sonar.api.web.UserRole;
import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.DbTester;
-import org.sonar.db.component.ComponentDbTester;
import org.sonar.db.component.ComponentDto;
import org.sonar.db.component.SnapshotDto;
import org.sonar.db.metric.MetricDto;
@@ -79,13 +78,10 @@ public class SearchActionTest {
@Rule
public DbTester db = DbTester.create(System2.INSTANCE);
- ComponentDbTester componentDb = new ComponentDbTester(db);
- DbClient dbClient = db.getDbClient();
- DbSession dbSession = db.getSession();
-
- UserDto user;
-
- WsActionTester ws = new WsActionTester(new SearchAction(userSession, dbClient));
+ private DbClient dbClient = db.getDbClient();
+ private DbSession dbSession = db.getSession();
+ private UserDto user;
+ private WsActionTester ws = new WsActionTester(new SearchAction(userSession, dbClient));
@Before
public void setUp() throws Exception {
@@ -109,7 +105,7 @@ public class SearchActionTest {
@Test
public void return_measures() throws Exception {
ComponentDto project = newProjectDto(db.getDefaultOrganization());
- SnapshotDto projectSnapshot = componentDb.insertProjectAndSnapshot(project);
+ SnapshotDto projectSnapshot = db.components().insertProjectAndSnapshot(project);
setBrowsePermissionOnUser(project);
MetricDto coverage = insertCoverageMetric();
dbClient.measureDao().insert(dbSession, newMeasureDto(coverage, project, projectSnapshot).setValue(15.5d));
@@ -127,7 +123,7 @@ public class SearchActionTest {
@Test
public void return_measures_on_leak_period() throws Exception {
ComponentDto project = newProjectDto(db.organizations().insert());
- SnapshotDto projectSnapshot = componentDb.insertProjectAndSnapshot(project);
+ SnapshotDto projectSnapshot = db.components().insertProjectAndSnapshot(project);
setBrowsePermissionOnUser(project);
MetricDto coverage = insertCoverageMetric();
dbClient.measureDao().insert(dbSession,
@@ -154,11 +150,11 @@ public class SearchActionTest {
MetricDto complexity = insertComplexityMetric();
OrganizationDto organizationDto = db.organizations().insert();
ComponentDto project1 = newProjectDto(organizationDto).setName("C");
- SnapshotDto projectSnapshot1 = componentDb.insertProjectAndSnapshot(project1);
+ SnapshotDto projectSnapshot1 = db.components().insertProjectAndSnapshot(project1);
ComponentDto project2 = newProjectDto(organizationDto).setName("A");
- SnapshotDto projectSnapshot2 = componentDb.insertProjectAndSnapshot(project2);
+ SnapshotDto projectSnapshot2 = db.components().insertProjectAndSnapshot(project2);
ComponentDto project3 = newProjectDto(organizationDto).setName("B");
- SnapshotDto projectSnapshot3 = componentDb.insertProjectAndSnapshot(project3);
+ SnapshotDto projectSnapshot3 = db.components().insertProjectAndSnapshot(project3);
setBrowsePermissionOnUser(project1, project2, project3);
dbClient.measureDao().insert(dbSession, newMeasureDto(coverage, project1, projectSnapshot1).setValue(5.5d));
dbClient.measureDao().insert(dbSession, newMeasureDto(coverage, project2, projectSnapshot2).setValue(6.5d));
@@ -180,9 +176,9 @@ public class SearchActionTest {
public void only_returns_authorized_projects() {
MetricDto metricDto = insertComplexityMetric();
ComponentDto project1 = newProjectDto(db.getDefaultOrganization());
- SnapshotDto projectSnapshot1 = componentDb.insertProjectAndSnapshot(project1);
+ SnapshotDto projectSnapshot1 = db.components().insertProjectAndSnapshot(project1);
ComponentDto project2 = newProjectDto(db.getDefaultOrganization());
- SnapshotDto projectSnapshot2 = componentDb.insertProjectAndSnapshot(project2);
+ SnapshotDto projectSnapshot2 = db.components().insertProjectAndSnapshot(project2);
dbClient.measureDao().insert(dbSession,
newMeasureDto(metricDto, project1, projectSnapshot1).setValue(15.5d),
newMeasureDto(metricDto, project2, projectSnapshot2).setValue(42.0d));
@@ -195,8 +191,25 @@ public class SearchActionTest {
}
@Test
+ public void do_not_verify_permissions_if_user_is_root() {
+ MetricDto metricDto = insertComplexityMetric();
+ ComponentDto project1 = newProjectDto(db.getDefaultOrganization());
+ SnapshotDto projectSnapshot1 = db.components().insertProjectAndSnapshot(project1);
+ dbClient.measureDao().insert(dbSession, newMeasureDto(metricDto, project1, projectSnapshot1).setValue(15.5d));
+ db.commit();
+
+ userSession.setNonRoot();
+ SearchWsResponse result = call(asList(project1.key()), singletonList("complexity"));
+ assertThat(result.getMeasuresCount()).isEqualTo(0);
+
+ userSession.setRoot();
+ result = call(asList(project1.key()), singletonList("complexity"));
+ assertThat(result.getMeasuresCount()).isEqualTo(1);
+ }
+
+ @Test
public void fail_if_no_metric() {
- ComponentDto project = componentDb.insertProject();
+ ComponentDto project = db.components().insertProject();
setBrowsePermissionOnUser(project);
expectedException.expect(IllegalArgumentException.class);
@@ -207,7 +220,7 @@ public class SearchActionTest {
@Test
public void fail_if_empty_metric() {
- ComponentDto project = componentDb.insertProject();
+ ComponentDto project = db.components().insertProject();
setBrowsePermissionOnUser(project);
expectedException.expect(IllegalArgumentException.class);
@@ -218,7 +231,7 @@ public class SearchActionTest {
@Test
public void fail_if_unknown_metric() {
- ComponentDto project = componentDb.insertProject();
+ ComponentDto project = db.components().insertProject();
setBrowsePermissionOnUser(project);
insertComplexityMetric();
@@ -251,7 +264,7 @@ public class SearchActionTest {
@Test
public void fail_if_more_than_100_project_keys() {
List<String> keys = IntStream.rangeClosed(1, 101)
- .mapToObj(i -> componentDb.insertProject())
+ .mapToObj(i -> db.components().insertProject())
.map(ComponentDto::key)
.collect(Collectors.toList());
insertComplexityMetric();
@@ -369,7 +382,7 @@ public class SearchActionTest {
ComponentDto project2 = newProjectDto(organizationDto).setKey("MY_PROJECT_2").setName("Project 2");
ComponentDto project3 = newProjectDto(organizationDto).setKey("MY_PROJECT_3").setName("Project 3");
projectKeys.addAll(asList(project1.key(), project2.key(), project3.key()));
- componentDb.insertComponents(project1, project2, project3);
+ db.components().insertComponents(project1, project2, project3);
SnapshotDto projectSnapshot1 = dbClient.snapshotDao().insert(dbSession, newAnalysis(project1)
.setPeriodDate(parseDateTime("2016-01-11T10:49:50+0100").getTime())
.setPeriodMode("previous_version")
diff --git a/server/sonar-server/src/test/java/org/sonar/server/permission/index/PermissionIndexerDaoTest.java b/server/sonar-server/src/test/java/org/sonar/server/permission/index/PermissionIndexerDaoTest.java
index cf3f11834ca..b39d94c0224 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/permission/index/PermissionIndexerDaoTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/permission/index/PermissionIndexerDaoTest.java
@@ -95,21 +95,21 @@ public class PermissionIndexerDaoTest {
PermissionIndexerDao.Dto view1Authorization = getByProjectUuid(view1.uuid(), dtos);
assertThat(view1Authorization.getGroupIds()).containsOnly(group.getId());
- assertThat(view1Authorization.isAllowAnyone()).isTrue();
+ assertThat(view1Authorization.isAllowAnyone()).isFalse();
assertThat(view1Authorization.getUserIds()).containsOnly(user1.getId());
assertThat(view1Authorization.getUpdatedAt()).isNotNull();
assertThat(view1Authorization.getQualifier()).isEqualTo(VIEW);
PermissionIndexerDao.Dto project2Authorization = getByProjectUuid(project2.uuid(), dtos);
assertThat(project2Authorization.getGroupIds()).isEmpty();
- assertThat(project2Authorization.isAllowAnyone()).isTrue();
+ assertThat(project2Authorization.isAllowAnyone()).isFalse();
assertThat(project2Authorization.getUserIds()).containsOnly(user1.getId(), user2.getId());
assertThat(project2Authorization.getUpdatedAt()).isNotNull();
assertThat(project2Authorization.getQualifier()).isEqualTo(PROJECT);
PermissionIndexerDao.Dto view2Authorization = getByProjectUuid(view2.uuid(), dtos);
assertThat(view2Authorization.getGroupIds()).isEmpty();
- assertThat(view2Authorization.isAllowAnyone()).isTrue();
+ assertThat(view2Authorization.isAllowAnyone()).isFalse();
assertThat(view2Authorization.getUserIds()).containsOnly(user1.getId(), user2.getId());
assertThat(view2Authorization.getUpdatedAt()).isNotNull();
assertThat(view2Authorization.getQualifier()).isEqualTo(VIEW);
@@ -133,21 +133,21 @@ public class PermissionIndexerDaoTest {
PermissionIndexerDao.Dto view1Authorization = dtos.get(view1.uuid());
assertThat(view1Authorization.getGroupIds()).containsOnly(group.getId());
- assertThat(view1Authorization.isAllowAnyone()).isTrue();
+ assertThat(view1Authorization.isAllowAnyone()).isFalse();
assertThat(view1Authorization.getUserIds()).containsOnly(user1.getId());
assertThat(view1Authorization.getUpdatedAt()).isNotNull();
assertThat(view1Authorization.getQualifier()).isEqualTo(VIEW);
PermissionIndexerDao.Dto project2Authorization = dtos.get(project2.uuid());
assertThat(project2Authorization.getGroupIds()).isEmpty();
- assertThat(project2Authorization.isAllowAnyone()).isTrue();
+ assertThat(project2Authorization.isAllowAnyone()).isFalse();
assertThat(project2Authorization.getUserIds()).containsOnly(user1.getId(), user2.getId());
assertThat(project2Authorization.getUpdatedAt()).isNotNull();
assertThat(project2Authorization.getQualifier()).isEqualTo(PROJECT);
PermissionIndexerDao.Dto view2Authorization = dtos.get(view2.uuid());
assertThat(view2Authorization.getGroupIds()).isEmpty();
- assertThat(view2Authorization.isAllowAnyone()).isTrue();
+ assertThat(view2Authorization.isAllowAnyone()).isFalse();
assertThat(view2Authorization.getUserIds()).containsOnly(user1.getId(), user2.getId());
assertThat(view2Authorization.getUpdatedAt()).isNotNull();
assertThat(view2Authorization.getQualifier()).isEqualTo(VIEW);
@@ -176,16 +176,17 @@ public class PermissionIndexerDaoTest {
}
@Test
- public void return_zero_rows_if_no_authorization() {
- userDbTester.insertProjectPermissionOnUser(user1, USER, project2);
- userDbTester.insertProjectPermissionOnGroup(group, USER, project2);
- userDbTester.insertProjectPermissionOnUser(user1, USER, view2);
- userDbTester.insertProjectPermissionOnGroup(group, USER, view2);
-
- Collection<PermissionIndexerDao.Dto> dtos = underTest.selectAll(dbClient, dbSession);
-
- // project1 and view1 don't have any permission
- assertThat(dtos).extracting(PermissionIndexerDao.Dto::getProjectUuid).containsOnly(project2.uuid(), view2.uuid());
+ public void return_project_without_permission_if_no_authorization() {
+ List<PermissionIndexerDao.Dto> dtos = underTest.selectByUuids(dbClient, dbSession, asList(project1.uuid()));
+
+ // no permissions
+ assertThat(dtos).hasSize(1);
+ PermissionIndexerDao.Dto dto = dtos.get(0);
+ assertThat(dto.getGroupIds()).isEmpty();
+ assertThat(dto.getUserIds()).isEmpty();
+ assertThat(dto.isAllowAnyone()).isFalse();
+ assertThat(dto.getProjectUuid()).isEqualTo(project1.uuid());
+ assertThat(dto.getQualifier()).isEqualTo(project1.qualifier());
}
private static PermissionIndexerDao.Dto getByProjectUuid(String projectUuid, Collection<PermissionIndexerDao.Dto> dtos) {
@@ -214,9 +215,5 @@ public class PermissionIndexerDaoTest {
// Anyone group has user access on both projects
userDbTester.insertProjectPermissionOnAnyone(USER, project1);
userDbTester.insertProjectPermissionOnAnyone(ADMIN, project1);
- userDbTester.insertProjectPermissionOnAnyone(USER, project2);
- userDbTester.insertProjectPermissionOnAnyone(USER, view1);
- userDbTester.insertProjectPermissionOnAnyone(ADMIN, view1);
- userDbTester.insertProjectPermissionOnAnyone(USER, view2);
}
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/project/ws/IndexActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/project/ws/IndexActionTest.java
index 12a268a3a6b..cb19ed6b295 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/project/ws/IndexActionTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/project/ws/IndexActionTest.java
@@ -169,6 +169,28 @@ public class IndexActionTest {
}
@Test
+ public void do_not_verify_permissions_if_user_is_root() throws Exception {
+ ComponentDto project = db.components().insertProject(p -> p.setKey("P1").setName("POne"));
+
+ String result = call(null, null, null);
+
+ userSession.setNonRoot();
+ assertThat(result).isEqualTo("[]");
+
+ userSession.setRoot();
+ result = call(null, null, null);
+ assertJson(result).isSimilarTo("[" +
+ " {" +
+ " \"id\":" + project.getId() + "," +
+ " \"k\":\"P1\"," +
+ " \"nm\":\"POne\"," +
+ " \"sc\":\"PRJ\"," +
+ " \"qu\":\"TRK\"" +
+ " }" +
+ "]");
+ }
+
+ @Test
public void test_example() {
insertProjectsAuthorizedForUser(
newProjectDto(db.getDefaultOrganization()).setKey("org.jenkins-ci.plugins:sonar").setName("Jenkins Sonar Plugin"),
@@ -199,7 +221,6 @@ public class IndexActionTest {
private void insertProjectsAuthorizedForUser(ComponentDto... projects) {
db.components().insertComponents(projects);
setBrowsePermissionOnUser(projects);
- db.commit();
}
private void setBrowsePermissionOnUser(ComponentDto... projects) {
diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualitygate/QgateProjectFinderTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualitygate/QgateProjectFinderTest.java
index 122ac05ec34..3d9ff6a34c6 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/qualitygate/QgateProjectFinderTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/qualitygate/QgateProjectFinderTest.java
@@ -37,6 +37,7 @@ import org.sonar.db.component.ComponentDto;
import org.sonar.db.organization.OrganizationDto;
import org.sonar.db.property.PropertyDto;
import org.sonar.db.qualitygate.ProjectQgateAssociation;
+import org.sonar.db.qualitygate.ProjectQgateAssociationQuery;
import org.sonar.db.qualitygate.QualityGateDto;
import org.sonar.db.user.UserDto;
import org.sonar.server.exceptions.NotFoundException;
@@ -160,6 +161,21 @@ public class QgateProjectFinderTest {
}
@Test
+ public void do_not_verify_permissions_if_user_is_root() throws Exception {
+ OrganizationDto org = dbTester.organizations().insert();
+ ComponentDto project = componentDbTester.insertProject(org);
+ ProjectQgateAssociationQuery query = builder()
+ .gateId(Long.toString(qGate.getId()))
+ .build();
+
+ userSession.logIn().setNonRoot();
+ verifyProjects(underTest.find(query));
+
+ userSession.logIn().setRoot();
+ verifyProjects(underTest.find(query), project.getId());
+ }
+
+ @Test
public void test_paging() throws Exception {
OrganizationDto org = dbTester.organizations().insert();
ComponentDto project1 = insertProjectAuthorizedToAnyone(newProjectDto(org).setName("Project 1"));
diff --git a/travis.sh b/travis.sh
index 29b81702d28..50aa00508e5 100755
--- a/travis.sh
+++ b/travis.sh
@@ -52,22 +52,21 @@ function installMaven {
export M2_HOME=~/maven/apache-maven-3.3.9
export PATH=$M2_HOME/bin:$PATH
}
+
#
-# Replaces the SNAPSHOT version by a version identifying the build.
+# Replaces the version defined in sources, usually x.y-SNAPSHOT,
+# by a version identifying the build.
+# The build version is composed of 4 fields, including the semantic version and
+# the build number provided by Travis.
#
-# Exports the variables:
+# Exported variables:
# - INITIAL_VERSION: version as defined in pom.xml
# - PROJECT_VERSION: build version. The name of this variable is important because
# it's used by QA when extracting version from Artifactory build info.
#
-# The build version is composed of 4 fields, including the semantic version and
-# the build number provided by Travis.
-#
# Example
-# Before: 6.3-SNAPSHOT
-# After: 6.3.0.12345
-#
-# Exception: GA release like "6.3" is kept as-is.
+# INITIAL_VERSION=6.3-SNAPSHOT
+# PROJECT_VERSION=6.3.0.12345
#
function fixBuildVersion {
export INITIAL_VERSION=`maven_expression "project.version"`
@@ -88,10 +87,7 @@ function fixBuildVersion {
echo "Source Version: $INITIAL_VERSION"
echo "Build Version : $PROJECT_VERSION"
- if [[ "$INITIAL_VERSION" == *"-"* ]]; then
- # SNAPSHOT or RC
- mvn org.codehaus.mojo:versions-maven-plugin:2.2:set -DnewVersion=$PROJECT_VERSION -DgenerateBackupPoms=false -B -e
- fi
+ mvn org.codehaus.mojo:versions-maven-plugin:2.2:set -DnewVersion=$PROJECT_VERSION -DgenerateBackupPoms=false -B -e
}
#