diff options
Diffstat (limited to 'server')
4 files changed, 38 insertions, 9 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CreateAction.java b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CreateAction.java index af5c91f22ef..68d28fb9401 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CreateAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CreateAction.java @@ -21,6 +21,7 @@ package org.sonar.server.measure.custom.ws; import java.net.HttpURLConnection; +import org.sonar.api.resources.Qualifiers; import org.sonar.api.server.ws.Request; import org.sonar.api.server.ws.Response; import org.sonar.api.server.ws.WebService; @@ -73,7 +74,7 @@ public class CreateAction implements CustomMeasuresWsAction { public void define(WebService.NewController context) { WebService.NewAction action = context.createAction(ACTION) .setDescription("Create a custom measure.<br /> " + - "The project id or the project key must be provided. The metric id or the metric key must be provided.<br/>" + + "The project id or the project key must be provided (only project and module custom measures can be created). The metric id or the metric key must be provided.<br/>" + "Requires 'Administer System' permission or 'Administer' permission on the project.") .setSince("5.2") .setPost(true) @@ -116,6 +117,7 @@ public class CreateAction implements CustomMeasuresWsAction { ComponentDto component = searchProject(dbSession, request); MetricDto metric = searchMetric(dbSession, request); checkPermissions(component); + checkIsProjectOrModule(component); checkMeasureDoesNotExistAlready(dbSession, component, metric); UserDoc user = userIndex.getByLogin(userSession.getLogin()); CustomMeasureDto measure = new CustomMeasureDto() @@ -124,7 +126,8 @@ public class CreateAction implements CustomMeasuresWsAction { .setMetricId(metric.getId()) .setDescription(description) .setUserLogin(user.login()) - .setCreatedAt(now); + .setCreatedAt(now) + .setUpdatedAt(now); validator.setMeasureValue(measure, valueAsString, metric); dbClient.customMeasureDao().insert(dbSession, measure); dbSession.commit(); @@ -137,6 +140,12 @@ public class CreateAction implements CustomMeasuresWsAction { } } + private static void checkIsProjectOrModule(ComponentDto component) { + if (!Qualifiers.PROJECT.equals(component.qualifier()) && !Qualifiers.MODULE.equals(component.qualifier())) { + throw new ServerException(HttpURLConnection.HTTP_CONFLICT, String.format("Component '%s' (id: %s) must be a project or a module.", component.key(), component.uuid())); + } + } + private void checkPermissions(ComponentDto component) { if (userSession.hasGlobalPermission(GlobalPermissions.SYSTEM_ADMIN)) { return; @@ -148,8 +157,8 @@ public class CreateAction implements CustomMeasuresWsAction { private void checkMeasureDoesNotExistAlready(DbSession dbSession, ComponentDto component, MetricDto metric) { int nbMeasuresOnSameMetricAndMeasure = dbClient.customMeasureDao().countByComponentIdAndMetricId(dbSession, component.uuid(), metric.getId()); if (nbMeasuresOnSameMetricAndMeasure > 0) { - throw new ServerException(HttpURLConnection.HTTP_CONFLICT, String.format("A measure already exists for project id '%s' and metric id '%d'", - component.uuid(), metric.getId())); + throw new ServerException(HttpURLConnection.HTTP_CONFLICT, String.format("A measure already exists for project '%s' (id: %s) and metric '%s' (id: '%d')", + component.key(), component.uuid(), metric.getKey(), metric.getId())); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CustomMeasureValidator.java b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CustomMeasureValidator.java index 2d38586da01..c7d76c7d1bc 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CustomMeasureValidator.java +++ b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/CustomMeasureValidator.java @@ -66,7 +66,7 @@ public class CustomMeasureValidator { throw new IllegalArgumentException("Unsupported metric type:" + metricType.description()); } } catch (Exception e) { - throw new IllegalArgumentException(String.format("Ill formatted value '%s' for metric type '%s'", valueAsString, metricType.description()), e); + throw new IllegalArgumentException(String.format("Incorrect value '%s' for metric type '%s'", valueAsString, metricType.description()), e); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CreateActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CreateActionTest.java index fdc8581c9f0..c16cdc30736 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CreateActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CreateActionTest.java @@ -35,6 +35,7 @@ import org.sonar.api.measures.Metric; import org.sonar.api.measures.Metric.ValueType; import org.sonar.api.utils.System2; import org.sonar.api.web.UserRole; +import org.sonar.core.component.ComponentDto; import org.sonar.core.measure.custom.db.CustomMeasureDto; import org.sonar.core.metric.db.MetricDto; import org.sonar.core.permission.GlobalPermissions; @@ -367,7 +368,7 @@ public class CreateActionTest { MetricDto metric = insertMetricAndProject(ValueType.STRING, DEFAULT_PROJECT_UUID); expectedException.expect(ServerException.class); - expectedException.expectMessage(String.format("A measure already exists for project id 'project-uuid' and metric id '%d'", metric.getId())); + expectedException.expectMessage(String.format("A measure already exists for project 'project-key' (id: project-uuid) and metric 'metric-key' (id: '%d')", metric.getId())); newRequest() .setParam(CreateAction.PARAM_PROJECT_ID, DEFAULT_PROJECT_UUID) @@ -386,7 +387,7 @@ public class CreateActionTest { MetricDto metric = insertMetricAndProject(ValueType.BOOL, DEFAULT_PROJECT_UUID); expectedException.expect(IllegalArgumentException.class); - expectedException.expectMessage("Ill formatted value 'non-correct-boolean-value' for metric type 'Yes/No'"); + expectedException.expectMessage("Incorrect value 'non-correct-boolean-value' for metric type 'Yes/No'"); newRequest() .setParam(CreateAction.PARAM_PROJECT_ID, DEFAULT_PROJECT_UUID) @@ -408,6 +409,25 @@ public class CreateActionTest { .execute(); } + @Test + public void fail_when_not_a_project() throws Exception { + MetricDto metric = MetricTesting.newMetricDto().setEnabled(true).setValueType(ValueType.STRING.name()).setKey("metric-key"); + dbClient.metricDao().insert(dbSession, metric); + ComponentDto project = ComponentTesting.newProjectDto(DEFAULT_PROJECT_UUID).setKey(DEFAULT_PROJECT_KEY); + dbClient.componentDao().insert(dbSession, project); + dbClient.componentDao().insert(dbSession, ComponentTesting.newDirectory(project, "directory-uuid", "path/to/directory").setKey("directory-key")); + dbSession.commit(); + + expectedException.expect(ServerException.class); + expectedException.expectMessage("Component 'directory-key' (id: directory-uuid) must be a project or a module."); + + newRequest() + .setParam(CreateAction.PARAM_PROJECT_ID, "directory-uuid") + .setParam(CreateAction.PARAM_METRIC_ID, metric.getId().toString()) + .setParam(CreateAction.PARAM_VALUE, "whatever-value") + .execute(); + } + private WsTester.TestRequest newRequest() { return ws.newPostRequest(CustomMeasuresWs.ENDPOINT, CreateAction.ACTION); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CustomMeasureValidatorTest.java b/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CustomMeasureValidatorTest.java index c546022eee8..456769345bc 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CustomMeasureValidatorTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/measure/custom/ws/CustomMeasureValidatorTest.java @@ -97,7 +97,7 @@ public class CustomMeasureValidatorTest { @Test public void fail_when_non_compliant_value() { expectedException.expect(IllegalArgumentException.class); - expectedException.expectMessage("Ill formatted value 'non-compliant-boolean-value' for metric type 'Yes/No'"); + expectedException.expectMessage("Incorrect value 'non-compliant-boolean-value' for metric type 'Yes/No'"); sut.setMeasureValue(customMeasure, "non-compliant-boolean-value", newMetricDto().setValueType(BOOL.name())); } @@ -105,7 +105,7 @@ public class CustomMeasureValidatorTest { @Test public void fail_when_non_compliant_level_value() { expectedException.expect(IllegalArgumentException.class); - expectedException.expectMessage("Ill formatted value 'non-compliant-level-value' for metric type 'Level'"); + expectedException.expectMessage("Incorrect value 'non-compliant-level-value' for metric type 'Level'"); sut.setMeasureValue(customMeasure, "non-compliant-level-value", newMetricDto().setValueType(LEVEL.name())); } |