aboutsummaryrefslogtreecommitdiffstats
path: root/tests/src/test/java/org
diff options
context:
space:
mode:
Diffstat (limited to 'tests/src/test/java/org')
-rw-r--r--tests/src/test/java/org/sonarqube/tests/plugins/checks/JavascriptCheck.java2
-rw-r--r--tests/src/test/java/org/sonarqube/tests/plugins/checks/Validation.java43
2 files changed, 33 insertions, 12 deletions
diff --git a/tests/src/test/java/org/sonarqube/tests/plugins/checks/JavascriptCheck.java b/tests/src/test/java/org/sonarqube/tests/plugins/checks/JavascriptCheck.java
index 40f74d64943..7fffd855060 100644
--- a/tests/src/test/java/org/sonarqube/tests/plugins/checks/JavascriptCheck.java
+++ b/tests/src/test/java/org/sonarqube/tests/plugins/checks/JavascriptCheck.java
@@ -30,6 +30,6 @@ public class JavascriptCheck implements Check {
validation.mustHaveComments(SRC_DIR);
validation.mustHaveComplexity(SRC_DIR);
validation.mustHaveIssues(SRC_DIR + "/HasIssues.js");
- validation.mustHaveMeasuresGreaterThan(SRC_DIR + "/Person.js", 0, "coverage");
+ validation.mustHaveMeasuresGreaterThanOrEquals(SRC_DIR + "/Person.js", 0, "coverage");
}
}
diff --git a/tests/src/test/java/org/sonarqube/tests/plugins/checks/Validation.java b/tests/src/test/java/org/sonarqube/tests/plugins/checks/Validation.java
index 9b2f9a4ea21..0c1a76dba73 100644
--- a/tests/src/test/java/org/sonarqube/tests/plugins/checks/Validation.java
+++ b/tests/src/test/java/org/sonarqube/tests/plugins/checks/Validation.java
@@ -22,18 +22,19 @@ package org.sonarqube.tests.plugins.checks;
import com.google.common.base.Joiner;
import com.google.gson.Gson;
import com.sonar.orchestrator.Orchestrator;
-import org.sonarqube.tests.plugins.Project;
import java.io.File;
import java.util.List;
import java.util.Map;
-import org.hamcrest.Matchers;
+import org.hamcrest.Description;
+import org.hamcrest.TypeSafeMatcher;
import org.junit.rules.ErrorCollector;
+import org.sonarqube.tests.plugins.Project;
import org.sonarqube.ws.client.GetRequest;
import org.sonarqube.ws.client.WsResponse;
import static java.util.Arrays.asList;
-import static org.hamcrest.CoreMatchers.is;
-import static org.hamcrest.CoreMatchers.notNullValue;
+import static org.hamcrest.core.Is.is;
+import static org.hamcrest.core.IsNull.notNullValue;
import static util.ItUtils.getMeasuresAsDoubleByMetricKey;
import static util.ItUtils.newAdminWsClient;
@@ -57,22 +58,22 @@ public class Validation {
public void mustHaveIssues(String path) {
// TODO use the WS api/issues
- mustHaveMeasuresGreaterThan(path, 1, "violations");
+ mustHaveMeasuresGreaterThanOrEquals(path, 1, "violations");
}
public void mustHaveComments(String path) {
- mustHaveMeasuresGreaterThan(path, 0, "comment_lines", "comment_lines_density");
+ mustHaveMeasuresGreaterThanOrEquals(path, 0, "comment_lines", "comment_lines_density");
}
public void mustHaveComplexity(String path) {
- mustHaveMeasuresGreaterThan(path, 0, "complexity");
+ mustHaveMeasuresGreaterThanOrEquals(path, 0, "complexity");
}
public void mustHaveSize(String path) {
- mustHaveMeasuresGreaterThan(path, 0, "ncloc", "lines");
+ mustHaveMeasuresGreaterThanOrEquals(path, 0, "ncloc", "lines");
}
- public void mustHaveMeasuresGreaterThan(String path, int min, String... metricKeys) {
+ public void mustHaveMeasuresGreaterThanOrEquals(String path, int min, String... metricKeys) {
for (String filePath : toFiles(path)) {
fileMustHaveMeasures(filePath, metricKeys, min);
}
@@ -87,7 +88,17 @@ public class Validation {
Double measure = measures.get(metricKey);
errorCollector.checkThat("Measure " + metricKey + " is set on file " + filePath, measure, notNullValue());
if (measure != null) {
- errorCollector.checkThat("Measure " + metricKey + " is positive on file " + filePath, measure.intValue(), Matchers.greaterThanOrEqualTo(min));
+ errorCollector.checkThat("Measure " + metricKey + " is positive on file " + filePath, measure.intValue(), new TypeSafeMatcher<Integer>() {
+ @Override
+ protected boolean matchesSafely(Integer item) {
+ return item >= min;
+ }
+
+ @Override
+ public void describeTo(Description description) {
+ description.appendText(metricKey).appendValue(min);
+ }
+ });
}
}
}
@@ -111,7 +122,17 @@ public class Validation {
errorCollector.checkThat("Source is set on file " + filePath, response.isSuccessful(), is(true));
Sources source = Sources.parse(response.content());
if (source != null) {
- errorCollector.checkThat("Source is empty on file " + filePath, source.getSources().size(), Matchers.greaterThanOrEqualTo(minLines));
+ errorCollector.checkThat("Source is empty on file " + filePath, source.getSources().size(), new TypeSafeMatcher<Integer>() {
+ @Override
+ protected boolean matchesSafely(Integer item) {
+ return item >= minLines;
+ }
+
+ @Override
+ public void describeTo(Description description) {
+ description.appendValue(minLines);
+ }
+ });
}
}
}