aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-plugin-api
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-plugin-api')
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinition.java22
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/measures/Metric.java31
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/utils/ZipUtils.java34
-rw-r--r--sonar-plugin-api/src/test/java/org/sonar/api/server/ws/internal/SimpleGetRequestTest.java35
4 files changed, 73 insertions, 49 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinition.java b/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinition.java
index 6f734e84c59..01ab0eedb08 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinition.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/config/PropertyDefinition.java
@@ -27,6 +27,7 @@ import java.util.ArrayList;
import java.util.Arrays;
import java.util.EnumMap;
import java.util.List;
+import java.util.function.Function;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;
import javax.annotation.Nullable;
@@ -165,12 +166,12 @@ public final class PropertyDefinition {
return Result.SUCCESS;
}
- EnumMap<PropertyType, Validation> validations = createValidations(options);
- return validations.getOrDefault(type, aValue -> Result.SUCCESS).validate(value);
+ EnumMap<PropertyType, Function<String, Result>> validations = createValidations(options);
+ return validations.getOrDefault(type, aValue -> Result.SUCCESS).apply(value);
}
- private static EnumMap<PropertyType, Validation> createValidations(List<String> options) {
- return new EnumMap<>(ImmutableMap.<PropertyType, Validation>builder()
+ private static EnumMap<PropertyType, Function<String, Result>> createValidations(List<String> options) {
+ return new EnumMap<>(ImmutableMap.<PropertyType, Function<String, Result>>builder()
.put(BOOLEAN, validateBoolean())
.put(INTEGER, validateInteger())
.put(LONG, validateInteger())
@@ -181,7 +182,7 @@ public final class PropertyDefinition {
.build());
}
- private static Validation validateBoolean() {
+ private static Function<String, Result> validateBoolean() {
return value -> {
if (!StringUtils.equalsIgnoreCase(value, "true") && !StringUtils.equalsIgnoreCase(value, "false")) {
return Result.newError("notBoolean");
@@ -190,7 +191,7 @@ public final class PropertyDefinition {
};
}
- private static Validation validateInteger() {
+ private static Function<String, Result> validateInteger() {
return value -> {
if (!NumberUtils.isDigits(value)) {
return Result.newError("notInteger");
@@ -199,7 +200,7 @@ public final class PropertyDefinition {
};
}
- private static Validation validateFloat() {
+ private static Function<String, Result> validateFloat() {
return value -> {
try {
Double.parseDouble(value);
@@ -210,7 +211,7 @@ public final class PropertyDefinition {
};
}
- private static Validation validateRegexp() {
+ private static Function<String, Result> validateRegexp() {
return value -> {
try {
Pattern.compile(value);
@@ -575,9 +576,4 @@ public final class PropertyDefinition {
}
}
}
-
- @FunctionalInterface
- private interface Validation {
- Result validate(String value);
- }
}
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/measures/Metric.java b/sonar-plugin-api/src/main/java/org/sonar/api/measures/Metric.java
index 2fdfbff01f2..30430453b4b 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/measures/Metric.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/measures/Metric.java
@@ -19,13 +19,11 @@
*/
package org.sonar.api.measures;
-import com.google.common.base.Function;
-import com.google.common.collect.Lists;
import java.io.Serializable;
import java.util.Arrays;
import java.util.List;
+import java.util.stream.Collectors;
import javax.annotation.CheckForNull;
-import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import org.apache.commons.lang.builder.ReflectionToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
@@ -40,7 +38,7 @@ import static org.apache.commons.lang.StringUtils.isNotBlank;
/**
* Used to define a metric in a plugin. Should be used with {@link Metrics} extension point.
- * Should no more be used on scanner side. Use {@link org.sonar.api.batch.measure.Metric} instead.
+ * Should no more be used on scanner side. Use {@link org.sonar.api.batch.measure.Metric} instead.
*/
@ScannerSide
@InstantiationStrategy(InstantiationStrategy.PER_BATCH)
@@ -55,6 +53,7 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
/**
* The maximum supported value of scale for decimal metrics
+ *
* @since 5.3
*/
public static final int MAX_DECIMAL_SCALE = 5;
@@ -109,13 +108,9 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
public enum Level {
OK("Green"), WARN("Orange"), ERROR("Red");
- private static final List<String> NAMES = Lists.transform(Arrays.asList(values()), new Function<Level, String>() {
- @Nonnull
- @Override
- public String apply(@Nonnull Level level) {
- return level.name();
- }
- });
+ private static final List<String> NAMES = Arrays.stream(values())
+ .map(Level::name)
+ .collect(Collectors.toList());
private String colorName;
@@ -521,6 +516,7 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
/**
* Return the number scale if metric type is {@link ValueType#FLOAT}, else {@code null}
+ *
* @since 5.3
*/
@CheckForNull
@@ -631,12 +627,11 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
* </ul>
* Metric.DIRECTION_NONE is the default value.
*
+ * @param d the direction
+ * @return the builder
* @see Metric#DIRECTION_WORST
* @see Metric#DIRECTION_BETTER
* @see Metric#DIRECTION_NONE
- *
- * @param d the direction
- * @return the builder
*/
public Builder setDirection(Integer d) {
this.direction = d;
@@ -680,7 +675,6 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
*
* @param f the formula
* @return the builder
- *
* @deprecated since 5.2, it's no more possible to define a formula on a metric, please use {@link org.sonar.api.ce.measure.MeasureComputer} instead
*/
@Deprecated
@@ -741,10 +735,9 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
/**
* Specifies whether this metric can be edited online in the "Manual measures" page. Default is false.
*
- * @since 2.10
- *
* @param b true if the metric can be edited online.
* @return the builder
+ * @since 2.10
*/
public Builder setUserManaged(boolean b) {
this.userManaged = b;
@@ -756,10 +749,9 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
* <br>
* By default, historical data are kept.
*
- * @since 2.14
- *
* @param b true if measures from the past can be deleted automatically.
* @return the builder
+ * @since 2.14
*/
public Builder setDeleteHistoricalData(boolean b) {
this.deleteHistoricalData = b;
@@ -769,6 +761,7 @@ public class Metric<G extends Serializable> implements Serializable, org.sonar.a
/**
* Scale to be used if the metric has decimal type ({@link ValueType#FLOAT} or {@link ValueType#PERCENT}).
* Default is 1. It is not set (({@code null}) on non-decimal metrics.
+ *
* @since 5.3
*/
public Builder setDecimalScale(int scale) {
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/utils/ZipUtils.java b/sonar-plugin-api/src/main/java/org/sonar/api/utils/ZipUtils.java
index e1dd34718c5..0cd98837689 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/utils/ZipUtils.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/utils/ZipUtils.java
@@ -54,11 +54,11 @@ public final class ZipUtils {
* @return the target directory
*/
public static File unzip(File zip, File toDir) throws IOException {
- return unzip(zip, toDir, (Predicate<ZipEntry>)ze -> true);
+ return unzip(zip, toDir, (Predicate<ZipEntry>) ze -> true);
}
public static File unzip(InputStream zip, File toDir) throws IOException {
- return unzip(zip, toDir, (Predicate<ZipEntry>)ze -> true);
+ return unzip(zip, toDir, (Predicate<ZipEntry>) ze -> true);
}
/**
@@ -71,8 +71,9 @@ public final class ZipUtils {
/**
* Unzip a file to a directory.
+ *
* @param stream the zip input file
- * @param toDir the target directory. It is created if needed.
+ * @param toDir the target directory. It is created if needed.
* @param filter filter zip entries so that only a subset of directories/files can be
* extracted to target directory.
* @return the parameter {@code toDir}
@@ -88,14 +89,7 @@ public final class ZipUtils {
ZipEntry entry;
while ((entry = zipStream.getNextEntry()) != null) {
if (filter.test(entry)) {
- File to = new File(toDir, entry.getName());
- if (entry.isDirectory()) {
- throwExceptionIfDirectoryIsNotCreatable(to);
- } else {
- File parent = to.getParentFile();
- throwExceptionIfDirectoryIsNotCreatable(parent);
- copy(zipStream, to);
- }
+ unzipEntry(entry, zipStream, toDir);
}
}
return toDir;
@@ -105,6 +99,17 @@ public final class ZipUtils {
}
}
+ private static void unzipEntry(ZipEntry entry, ZipInputStream zipStream, File toDir) throws IOException {
+ File to = new File(toDir, entry.getName());
+ if (entry.isDirectory()) {
+ throwExceptionIfDirectoryIsNotCreatable(to);
+ } else {
+ File parent = to.getParentFile();
+ throwExceptionIfDirectoryIsNotCreatable(parent);
+ copy(zipStream, to);
+ }
+ }
+
private static void throwExceptionIfDirectoryIsNotCreatable(File to) throws IOException {
if (!to.exists() && !to.mkdirs()) {
throw new IOException(ERROR_CREATING_DIRECTORY + to);
@@ -121,8 +126,9 @@ public final class ZipUtils {
/**
* Unzip a file to a directory.
- * @param zip the zip file. It must exist.
- * @param toDir the target directory. It is created if needed.
+ *
+ * @param zip the zip file. It must exist.
+ * @param toDir the target directory. It is created if needed.
* @param filter filter zip entries so that only a subset of directories/files can be
* extracted to target directory.
* @return the parameter {@code toDir}
@@ -233,8 +239,8 @@ public final class ZipUtils {
}
/**
- * @deprecated replaced by {@link Predicate<ZipEntry>} in 6.2.
* @see #unzip(File, File, Predicate)
+ * @deprecated replaced by {@link Predicate<ZipEntry>} in 6.2.
*/
@Deprecated
@FunctionalInterface
diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/server/ws/internal/SimpleGetRequestTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/server/ws/internal/SimpleGetRequestTest.java
index 08f69177262..650b9ace11e 100644
--- a/sonar-plugin-api/src/test/java/org/sonar/api/server/ws/internal/SimpleGetRequestTest.java
+++ b/sonar-plugin-api/src/test/java/org/sonar/api/server/ws/internal/SimpleGetRequestTest.java
@@ -19,13 +19,14 @@
*/
package org.sonar.api.server.ws.internal;
-import static org.assertj.core.api.Assertions.assertThat;
-import static org.mockito.Mockito.mock;
-
import java.io.InputStream;
import org.junit.Test;
import org.sonar.api.server.ws.Request;
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.assertj.core.api.Assertions.entry;
+import static org.mockito.Mockito.mock;
+
public class SimpleGetRequestTest {
SimpleGetRequest underTest = new SimpleGetRequest();
@@ -59,4 +60,32 @@ public class SimpleGetRequestTest {
assertThat(underTest.paramAsPart("unknown")).isNull();
}
+
+ @Test
+ public void getMediaType() {
+ underTest.setMediaType("JSON");
+
+ assertThat(underTest.getMediaType()).isEqualTo("JSON");
+ }
+
+ @Test
+ public void multiParam_with_one_element() {
+ underTest.setParam("foo", "bar");
+
+ assertThat(underTest.multiParam("foo")).containsExactly("bar");
+ }
+
+ @Test
+ public void multiParam_without_any_element() {
+ assertThat(underTest.multiParam("42")).isEmpty();
+ }
+
+ @Test
+ public void getParams() {
+ underTest
+ .setParam("foo", "bar")
+ .setParam("fee", "beer");
+
+ assertThat(underTest.getParams()).containsOnly(entry("foo", "bar"), entry("fee", "beer"));
+ }
}