aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchAction.java121
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseData.java12
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseFormat.java19
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseLoader.java10
-rw-r--r--server/sonar-server/src/main/resources/org/sonar/server/issue/ws/example-search.json2
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/issue/ws/SearchActionMediumTest.java49
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/assigned_to_me_facet_sticky.json2
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_deprecated_debt_fields.json16
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets.json2
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_effort.json (renamed from server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_debt.json)4
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_zero_facets.json2
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/filter_by_assigned_to_me.json2
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/hide_rules.json2
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/response_contains_all_fields_except_additional_fields.json2
14 files changed, 150 insertions, 95 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchAction.java
index 115ffe639fa..30dc75db6aa 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchAction.java
@@ -47,7 +47,6 @@ import org.sonar.server.issue.index.IssueIndex;
import org.sonar.server.rule.RuleKeyFunctions;
import org.sonar.server.user.UserSession;
import org.sonarqube.ws.Issues.SearchWsResponse;
-import org.sonarqube.ws.client.issue.IssueFilterParameters;
import org.sonarqube.ws.client.issue.SearchWsRequest;
import static com.google.common.collect.FluentIterable.from;
@@ -73,8 +72,12 @@ import static org.sonarqube.ws.client.issue.IssueFilterParameters.CREATED_AFTER;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.CREATED_AT;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.CREATED_BEFORE;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.CREATED_IN_LAST;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.DEPRECATED_FACET_MODE_DEBT;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.DIRECTORIES;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.FACET_ASSIGNED_TO_ME;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.FACET_MODE;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.FACET_MODE_COUNT;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.FACET_MODE_EFFORT;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.FILE_UUIDS;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.ISSUES;
import static org.sonarqube.ws.client.issue.IssueFilterParameters.LANGUAGES;
@@ -119,7 +122,8 @@ public class SearchAction implements IssuesWsAction {
.createAction(SEARCH_ACTION)
.setHandler(this)
.setDescription(
- "Search for issues. Requires Browse permission on project(s)")
+ "Search for issues. Requires Browse permission on project(s).<br/>" +
+ "Since 5.5, response field 'debt' has been renamed to 'effort'")
.setSince("3.6")
.setResponseExample(Resources.getResource(this.getClass(), "example-search.json"));
@@ -127,41 +131,42 @@ public class SearchAction implements IssuesWsAction {
action.createParam(Param.FACETS)
.setDescription("Comma-separated list of the facets to be computed. No facet is computed by default.")
.setPossibleValues(IssueIndex.SUPPORTED_FACETS);
- action.createParam(IssueFilterParameters.FACET_MODE)
- .setDefaultValue(IssueFilterParameters.FACET_MODE_COUNT)
- .setDescription("Choose the returned value for facet items, either count of issues or sum of debt.")
- .setPossibleValues(IssueFilterParameters.FACET_MODE_COUNT, IssueFilterParameters.DEPRECATED_FACET_MODE_DEBT);
+ action.createParam(FACET_MODE)
+ .setDefaultValue(FACET_MODE_COUNT)
+ .setDescription("Choose the returned value for facet items, either count of issues or sum of debt.<br/>" +
+ "Since 5.5, 'debt' mode is deprecated and replaced by 'effort'")
+ .setPossibleValues(FACET_MODE_COUNT, FACET_MODE_EFFORT, DEPRECATED_FACET_MODE_DEBT);
action.addSortParams(IssueQuery.SORTS, null, true);
- action.createParam(IssueFilterParameters.ADDITIONAL_FIELDS)
+ action.createParam(ADDITIONAL_FIELDS)
.setSince("5.2")
.setDescription("Comma-separated list of the optional fields to be returned in response.")
.setPossibleValues(SearchAdditionalField.possibleValues());
addComponentRelatedParams(action);
- action.createParam(IssueFilterParameters.ISSUES)
+ action.createParam(ISSUES)
.setDescription("Comma-separated list of issue keys")
.setExampleValue("5bccd6e8-f525-43a2-8d76-fcb13dde79ef");
- action.createParam(IssueFilterParameters.SEVERITIES)
+ action.createParam(SEVERITIES)
.setDescription("Comma-separated list of severities")
.setExampleValue(Severity.BLOCKER + "," + Severity.CRITICAL)
.setPossibleValues(Severity.ALL);
- action.createParam(IssueFilterParameters.STATUSES)
+ action.createParam(STATUSES)
.setDescription("Comma-separated list of statuses")
.setExampleValue(Issue.STATUS_OPEN + "," + Issue.STATUS_REOPENED)
.setPossibleValues(Issue.STATUSES);
- action.createParam(IssueFilterParameters.RESOLUTIONS)
+ action.createParam(RESOLUTIONS)
.setDescription("Comma-separated list of resolutions")
.setExampleValue(Issue.RESOLUTION_FIXED + "," + Issue.RESOLUTION_REMOVED)
.setPossibleValues(Issue.RESOLUTIONS);
- action.createParam(IssueFilterParameters.RESOLVED)
+ action.createParam(RESOLVED)
.setDescription("To match resolved or unresolved issues")
.setBooleanPossibleValues();
- action.createParam(IssueFilterParameters.RULES)
+ action.createParam(RULES)
.setDescription("Comma-separated list of coding rule keys. Format is <repository>:<rule>")
.setExampleValue("squid:AvoidCycles");
- action.createParam(IssueFilterParameters.TAGS)
+ action.createParam(TAGS)
.setDescription("Comma-separated list of tags.")
.setExampleValue("security,convention");
- action.createParam(IssueFilterParameters.TYPES)
+ action.createParam(TYPES)
.setDescription("Comma-separated list of types.")
.setSince("5.5")
.setPossibleValues(RuleType.values())
@@ -169,34 +174,34 @@ public class SearchAction implements IssuesWsAction {
action.createParam(ACTION_PLANS)
.setDescription("Comma-separated list of action plan keys (not names)")
.setExampleValue("3f19de90-1521-4482-a737-a311758ff513");
- action.createParam(IssueFilterParameters.PLANNED)
+ action.createParam(PLANNED)
.setDescription("To retrieve issues associated to an action plan or not")
.setBooleanPossibleValues();
- action.createParam(IssueFilterParameters.REPORTERS)
+ action.createParam(REPORTERS)
.setDescription("Comma-separated list of reporter logins")
.setExampleValue("admin");
- action.createParam(IssueFilterParameters.AUTHORS)
+ action.createParam(AUTHORS)
.setDescription("Comma-separated list of SCM accounts")
.setExampleValue("torvalds@linux-foundation.org");
- action.createParam(IssueFilterParameters.ASSIGNEES)
+ action.createParam(ASSIGNEES)
.setDescription("Comma-separated list of assignee logins. The value '__me__' can be used as a placeholder for user who performs the request")
.setExampleValue("admin,usera,__me__");
- action.createParam(IssueFilterParameters.ASSIGNED)
+ action.createParam(ASSIGNED)
.setDescription("To retrieve assigned or unassigned issues")
.setBooleanPossibleValues();
- action.createParam(IssueFilterParameters.LANGUAGES)
+ action.createParam(LANGUAGES)
.setDescription("Comma-separated list of languages. Available since 4.4")
.setExampleValue("java,js");
- action.createParam(IssueFilterParameters.CREATED_AT)
+ action.createParam(CREATED_AT)
.setDescription("To retrieve issues created in a specific analysis, identified by an ISO-formatted datetime stamp.")
.setExampleValue("2013-05-01T13:00:00+0100");
- action.createParam(IssueFilterParameters.CREATED_AFTER)
+ action.createParam(CREATED_AFTER)
.setDescription("To retrieve issues created after the given date (exclusive). Format: date or datetime ISO formats. If this parameter is set, createdSince must not be set")
.setExampleValue("2013-05-01 (or 2013-05-01T13:00:00+0100)");
- action.createParam(IssueFilterParameters.CREATED_BEFORE)
+ action.createParam(CREATED_BEFORE)
.setDescription("To retrieve issues created before the given date (exclusive). Format: date or datetime ISO formats")
.setExampleValue("2013-05-01 (or 2013-05-01T13:00:00+0100)");
- action.createParam(IssueFilterParameters.CREATED_IN_LAST)
+ action.createParam(CREATED_IN_LAST)
.setDescription("To retrieve issues created during a time span before the current time (exclusive). " +
"Accepted units are 'y' for year, 'm' for month, 'w' for week and 'd' for day. " +
"If this parameter is set, createdAfter must not be set")
@@ -204,7 +209,7 @@ public class SearchAction implements IssuesWsAction {
}
private static void addComponentRelatedParams(WebService.NewAction action) {
- action.createParam(IssueFilterParameters.ON_COMPONENT_ONLY)
+ action.createParam(ON_COMPONENT_ONLY)
.setDescription("Return only issues at a component's level, not on its descendants (modules, directories, files, etc). " +
"This parameter is only considered when componentKeys or componentUuids is set. " +
"Using the deprecated componentRoots or componentRootUuids parameters will set this parameter to false. " +
@@ -212,56 +217,56 @@ public class SearchAction implements IssuesWsAction {
.setBooleanPossibleValues()
.setDefaultValue("false");
- action.createParam(IssueFilterParameters.COMPONENT_KEYS)
+ action.createParam(COMPONENT_KEYS)
.setDescription("To retrieve issues associated to a specific list of components sub-components (comma-separated list of component keys). " +
"A component can be a view, developer, project, module, directory or file. " +
"If this parameter is set, componentUuids must not be set.")
.setExampleValue(KEY_PROJECT_EXAMPLE_001);
- action.createParam(IssueFilterParameters.COMPONENTS)
+ action.createParam(COMPONENTS)
.setDeprecatedSince("5.1")
.setDescription("If used, will have the same meaning as componentKeys AND onComponentOnly=true.");
- action.createParam(IssueFilterParameters.COMPONENT_UUIDS)
+ action.createParam(COMPONENT_UUIDS)
.setDescription("To retrieve issues associated to a specific list of components their sub-components (comma-separated list of component UUIDs). " +
INTERNAL_PARAMETER_DISCLAIMER +
"A component can be a project, module, directory or file. " +
"If this parameter is set, componentKeys must not be set.")
.setExampleValue("584a89f2-8037-4f7b-b82c-8b45d2d63fb2");
- action.createParam(IssueFilterParameters.COMPONENT_ROOTS)
+ action.createParam(COMPONENT_ROOTS)
.setDeprecatedSince("5.1")
.setDescription("If used, will have the same meaning as componentKeys AND onComponentOnly=false.");
- action.createParam(IssueFilterParameters.COMPONENT_ROOT_UUIDS)
+ action.createParam(COMPONENT_ROOT_UUIDS)
.setDeprecatedSince("5.1")
.setDescription("If used, will have the same meaning as componentUuids AND onComponentOnly=false.");
- action.createParam(IssueFilterParameters.PROJECTS)
+ action.createParam(PROJECTS)
.setDeprecatedSince("5.1")
.setDescription("See projectKeys");
- action.createParam(IssueFilterParameters.PROJECT_KEYS)
+ action.createParam(PROJECT_KEYS)
.setDescription("To retrieve issues associated to a specific list of projects (comma-separated list of project keys). " +
INTERNAL_PARAMETER_DISCLAIMER +
"If this parameter is set, projectUuids must not be set.")
- .setDeprecatedKey(IssueFilterParameters.PROJECTS)
+ .setDeprecatedKey(PROJECTS)
.setExampleValue(KEY_PROJECT_EXAMPLE_001);
- action.createParam(IssueFilterParameters.PROJECT_UUIDS)
+ action.createParam(PROJECT_UUIDS)
.setDescription("To retrieve issues associated to a specific list of projects (comma-separated list of project UUIDs). " +
INTERNAL_PARAMETER_DISCLAIMER +
"Views are not supported. If this parameter is set, projectKeys must not be set.")
.setExampleValue("7d8749e8-3070-4903-9188-bdd82933bb92");
- action.createParam(IssueFilterParameters.MODULE_UUIDS)
+ action.createParam(MODULE_UUIDS)
.setDescription("To retrieve issues associated to a specific list of modules (comma-separated list of module UUIDs). " +
INTERNAL_PARAMETER_DISCLAIMER +
"Views are not supported. If this parameter is set, moduleKeys must not be set.")
.setExampleValue("7d8749e8-3070-4903-9188-bdd82933bb92");
- action.createParam(IssueFilterParameters.DIRECTORIES)
+ action.createParam(DIRECTORIES)
.setDescription("Since 5.1. To retrieve issues associated to a specific list of directories (comma-separated list of directory paths). " +
"This parameter is only meaningful when a module is selected. " +
INTERNAL_PARAMETER_DISCLAIMER)
.setExampleValue("src/main/java/org/sonar/server/");
- action.createParam(IssueFilterParameters.FILE_UUIDS)
+ action.createParam(FILE_UUIDS)
.setDescription("To retrieve issues associated to a specific list of files (comma-separated list of file UUIDs). " +
INTERNAL_PARAMETER_DISCLAIMER)
.setExampleValue("bdd82933-3070-4903-9188-7d8749e8bb92");
@@ -328,10 +333,10 @@ public class SearchAction implements IssuesWsAction {
}
private void completeFacets(Facets facets, SearchWsRequest request, Request wsRequest) {
- addMandatoryValuesToFacet(facets, IssueFilterParameters.SEVERITIES, Severity.ALL);
- addMandatoryValuesToFacet(facets, IssueFilterParameters.STATUSES, Issue.STATUSES);
- addMandatoryValuesToFacet(facets, IssueFilterParameters.RESOLUTIONS, concat(singletonList(""), Issue.RESOLUTIONS));
- addMandatoryValuesToFacet(facets, IssueFilterParameters.PROJECT_UUIDS, request.getProjectUuids());
+ addMandatoryValuesToFacet(facets, SEVERITIES, Severity.ALL);
+ addMandatoryValuesToFacet(facets, STATUSES, Issue.STATUSES);
+ addMandatoryValuesToFacet(facets, RESOLUTIONS, concat(singletonList(""), Issue.RESOLUTIONS));
+ addMandatoryValuesToFacet(facets, PROJECT_UUIDS, request.getProjectUuids());
List<String> assignees = Lists.newArrayList("");
List<String> assigneesFromRequest = request.getAssignees();
@@ -339,24 +344,24 @@ public class SearchAction implements IssuesWsAction {
assignees.addAll(assigneesFromRequest);
assignees.remove(IssueQueryService.LOGIN_MYSELF);
}
- addMandatoryValuesToFacet(facets, IssueFilterParameters.ASSIGNEES, assignees);
- addMandatoryValuesToFacet(facets, IssueFilterParameters.FACET_ASSIGNED_TO_ME, singletonList(userSession.getLogin()));
- addMandatoryValuesToFacet(facets, IssueFilterParameters.REPORTERS, request.getReporters());
- addMandatoryValuesToFacet(facets, IssueFilterParameters.RULES, request.getRules());
- addMandatoryValuesToFacet(facets, IssueFilterParameters.LANGUAGES, request.getLanguages());
- addMandatoryValuesToFacet(facets, IssueFilterParameters.TAGS, request.getTags());
- addMandatoryValuesToFacet(facets, IssueFilterParameters.TYPES, RuleType.ALL_NAMES);
+ addMandatoryValuesToFacet(facets, ASSIGNEES, assignees);
+ addMandatoryValuesToFacet(facets, FACET_ASSIGNED_TO_ME, singletonList(userSession.getLogin()));
+ addMandatoryValuesToFacet(facets, REPORTERS, request.getReporters());
+ addMandatoryValuesToFacet(facets, RULES, request.getRules());
+ addMandatoryValuesToFacet(facets, LANGUAGES, request.getLanguages());
+ addMandatoryValuesToFacet(facets, TAGS, request.getTags());
+ addMandatoryValuesToFacet(facets, TYPES, RuleType.ALL_NAMES);
List<String> actionPlans = Lists.newArrayList("");
List<String> actionPlansFromRequest = request.getActionPlans();
if (actionPlansFromRequest != null) {
actionPlans.addAll(actionPlansFromRequest);
}
addMandatoryValuesToFacet(facets, ACTION_PLANS, actionPlans);
- addMandatoryValuesToFacet(facets, IssueFilterParameters.COMPONENT_UUIDS, request.getComponentUuids());
+ addMandatoryValuesToFacet(facets, COMPONENT_UUIDS, request.getComponentUuids());
for (String facetName : request.getFacets()) {
LinkedHashMap<String, Long> buckets = facets.get(facetName);
- if (!IssueFilterParameters.FACET_ASSIGNED_TO_ME.equals(facetName)) {
+ if (!FACET_ASSIGNED_TO_ME.equals(facetName)) {
if (buckets != null) {
List<String> requestParams = wsRequest.paramAsStrings(facetName);
if (requestParams != null) {
@@ -390,16 +395,16 @@ public class SearchAction implements IssuesWsAction {
}
private void collectFacets(SearchResponseLoader.Collector collector, Facets facets) {
- Set<String> facetRules = facets.getBucketKeys(IssueFilterParameters.RULES);
+ Set<String> facetRules = facets.getBucketKeys(RULES);
if (facetRules != null) {
collector.addAll(SearchAdditionalField.RULES, from(facetRules).transform(RuleKeyFunctions.stringToRuleKey()));
}
- collector.addProjectUuids(facets.getBucketKeys(IssueFilterParameters.PROJECT_UUIDS));
- collector.addComponentUuids(facets.getBucketKeys(IssueFilterParameters.COMPONENT_UUIDS));
- collector.addComponentUuids(facets.getBucketKeys(IssueFilterParameters.FILE_UUIDS));
- collector.addComponentUuids(facets.getBucketKeys(IssueFilterParameters.MODULE_UUIDS));
- collector.addAll(SearchAdditionalField.USERS, facets.getBucketKeys(IssueFilterParameters.ASSIGNEES));
- collector.addAll(SearchAdditionalField.USERS, facets.getBucketKeys(IssueFilterParameters.REPORTERS));
+ collector.addProjectUuids(facets.getBucketKeys(PROJECT_UUIDS));
+ collector.addComponentUuids(facets.getBucketKeys(COMPONENT_UUIDS));
+ collector.addComponentUuids(facets.getBucketKeys(FILE_UUIDS));
+ collector.addComponentUuids(facets.getBucketKeys(MODULE_UUIDS));
+ collector.addAll(SearchAdditionalField.USERS, facets.getBucketKeys(ASSIGNEES));
+ collector.addAll(SearchAdditionalField.USERS, facets.getBucketKeys(REPORTERS));
collector.addAll(SearchAdditionalField.ACTION_PLANS, facets.getBucketKeys(ACTION_PLANS));
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseData.java b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseData.java
index a24ccaad198..877068ded6a 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseData.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseData.java
@@ -29,13 +29,13 @@ import java.util.Map;
import java.util.Set;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
-import org.sonar.server.issue.workflow.Transition;
import org.sonar.db.component.ComponentDto;
import org.sonar.db.issue.ActionPlanDto;
import org.sonar.db.issue.IssueChangeDto;
import org.sonar.db.issue.IssueDto;
import org.sonar.db.rule.RuleDto;
import org.sonar.db.user.UserDto;
+import org.sonar.server.issue.workflow.Transition;
import static com.google.common.base.Preconditions.checkNotNull;
@@ -46,7 +46,7 @@ public class SearchResponseData {
private final List<IssueDto> issues;
- private Long debtTotal = null;
+ private Long effortTotal = null;
private List<UserDto> users = null;
private List<RuleDto> rules = null;
private List<ActionPlanDto> actionPlans = null;
@@ -157,11 +157,11 @@ public class SearchResponseData {
}
@CheckForNull
- public Long getDebtTotal() {
- return debtTotal;
+ public Long getEffortTotal() {
+ return effortTotal;
}
- public void setDebtTotal(@Nullable Long debtTotal) {
- this.debtTotal = debtTotal;
+ public void setEffortTotal(@Nullable Long effortTotal) {
+ this.effortTotal = effortTotal;
}
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseFormat.java b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseFormat.java
index 25a6f08f1ef..b8417c74cac 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseFormat.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseFormat.java
@@ -69,7 +69,7 @@ public class SearchResponseFormat {
Issues.SearchWsResponse.Builder response = Issues.SearchWsResponse.newBuilder();
formatPaging(paging, response);
- formatDebtTotal(data, response);
+ formatEffortTotal(data, response);
response.addAllIssues(formatIssues(fields, data));
response.addAllComponents(formatComponents(data));
if (facets != null) {
@@ -109,10 +109,11 @@ public class SearchResponseFormat {
return response.build();
}
- private void formatDebtTotal(SearchResponseData data, Issues.SearchWsResponse.Builder response) {
- Long debt = data.getDebtTotal();
- if (debt != null) {
- response.setDebtTotal(debt);
+ private void formatEffortTotal(SearchResponseData data, Issues.SearchWsResponse.Builder response) {
+ Long effort = data.getEffortTotal();
+ if (effort != null) {
+ response.setDebtTotal(effort);
+ response.setEffortTotal(effort);
}
}
@@ -178,9 +179,11 @@ public class SearchResponseFormat {
}
issueBuilder.setMessage(nullToEmpty(dto.getMessage()));
issueBuilder.addAllTags(dto.getTags());
- Long debt = dto.getEffort();
- if (debt != null) {
- issueBuilder.setDebt(durations.encode(Duration.create(debt)));
+ Long effort = dto.getEffort();
+ if (effort != null) {
+ String effortValue = durations.encode(Duration.create(effort));
+ issueBuilder.setDebt(effortValue);
+ issueBuilder.setEffort(effortValue);
}
Integer line = dto.getLine();
if (line != null) {
diff --git a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseLoader.java b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseLoader.java
index 2f0afe9d863..457d804d810 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseLoader.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/issue/ws/SearchResponseLoader.java
@@ -84,7 +84,7 @@ public class SearchResponseLoader {
loadActionPlans(collector, dbSession, result);
loadComponents(collector, dbSession, result);
loadActionsAndTransitions(collector, result);
- completeTotalDebtFromFacet(facets, result);
+ completeTotalEffortFromFacet(facets, result);
return result;
} finally {
dbClient.closeSession(dbSession);
@@ -150,11 +150,11 @@ public class SearchResponseLoader {
}
}
- private void completeTotalDebtFromFacet(@Nullable Facets facets, SearchResponseData result) {
+ private void completeTotalEffortFromFacet(@Nullable Facets facets, SearchResponseData result) {
if (facets != null) {
- Map<String, Long> debtFacet = facets.get(IssueFilterParameters.FACET_MODE_EFFORT);
- if (debtFacet != null) {
- result.setDebtTotal(debtFacet.get(Facets.TOTAL));
+ Map<String, Long> effortFacet = facets.get(IssueFilterParameters.FACET_MODE_EFFORT);
+ if (effortFacet != null) {
+ result.setEffortTotal(effortFacet.get(Facets.TOTAL));
}
}
}
diff --git a/server/sonar-server/src/main/resources/org/sonar/server/issue/ws/example-search.json b/server/sonar-server/src/main/resources/org/sonar/server/issue/ws/example-search.json
index 61908702dd9..2bb9d5fc008 100644
--- a/server/sonar-server/src/main/resources/org/sonar/server/issue/ws/example-search.json
+++ b/server/sonar-server/src/main/resources/org/sonar/server/issue/ws/example-search.json
@@ -22,7 +22,7 @@
"endOffset": 134
},
"author": "Developer 1",
- "debt": "2h1min",
+ "effort": "2h1min",
"creationDate": "2013-05-13T17:55:39+0200",
"updateDate": "2013-05-13T17:55:39+0200",
"tags": ["bug"],
diff --git a/server/sonar-server/src/test/java/org/sonar/server/issue/ws/SearchActionMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/issue/ws/SearchActionMediumTest.java
index 41030157085..8b3ae1755e0 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/issue/ws/SearchActionMediumTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/issue/ws/SearchActionMediumTest.java
@@ -54,10 +54,16 @@ import org.sonar.server.search.QueryContext;
import org.sonar.server.tester.ServerTester;
import org.sonar.server.tester.UserSessionRule;
import org.sonar.server.ws.WsTester;
-import org.sonarqube.ws.client.issue.IssueFilterParameters;
import static java.util.Arrays.asList;
import static org.assertj.core.api.Assertions.assertThat;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.ADDITIONAL_FIELDS;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.COMPONENTS;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.DEPRECATED_FACET_MODE_DEBT;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.FACET_MODE_EFFORT;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.HIDE_COMMENTS;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.PAGE_INDEX;
+import static org.sonarqube.ws.client.issue.IssueFilterParameters.PAGE_SIZE;
public class SearchActionMediumTest {
@@ -203,7 +209,7 @@ public class SearchActionMediumTest {
tester.get(IssueIndexer.class).indexAll();
userSessionRule.login("john");
- WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(IssueFilterParameters.HIDE_COMMENTS, "true").execute();
+ WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(HIDE_COMMENTS, "true").execute();
result.assertJson(this.getClass(), "issue_with_comment_hidden.json");
assertThat(result.outputAsString()).doesNotContain("fabrice");
}
@@ -320,7 +326,7 @@ public class SearchActionMediumTest {
session.commit();
tester.get(IssueIndexer.class).indexAll();
- WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(IssueFilterParameters.COMPONENTS, file.getKey()).execute();
+ WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(COMPONENTS, file.getKey()).execute();
result.assertJson(this.getClass(), "apply_paging_with_one_component.json");
}
@@ -335,7 +341,7 @@ public class SearchActionMediumTest {
session.commit();
tester.get(IssueIndexer.class).indexAll();
- WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(IssueFilterParameters.ADDITIONAL_FIELDS, "_all").execute();
+ WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION).setParam(ADDITIONAL_FIELDS, "_all").execute();
result.assertJson(this.getClass(), "components_contains_sub_projects.json");
}
@@ -364,7 +370,7 @@ public class SearchActionMediumTest {
}
@Test
- public void display_facets_in_debt_mode() throws Exception {
+ public void display_facets_in_effort_mode() throws Exception {
ComponentDto project = insertComponent(ComponentTesting.newProjectDto("PROJECT_ID").setKey("PROJECT_KEY"));
setDefaultProjectPermission(project);
ComponentDto file = insertComponent(ComponentTesting.newFileDto(project, "FILE_ID").setKey("FILE_KEY"));
@@ -383,9 +389,9 @@ public class SearchActionMediumTest {
WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION)
.setParam("resolved", "false")
.setParam(WebService.Param.FACETS, "statuses,severities,resolutions,projectUuids,rules,fileUuids,assignees,languages,actionPlans")
- .setParam("facetMode", "debt")
+ .setParam("facetMode", FACET_MODE_EFFORT)
.execute();
- result.assertJson(this.getClass(), "display_facets_debt.json");
+ result.assertJson(this.getClass(), "display_facets_effort.json");
}
@Test
@@ -613,8 +619,8 @@ public class SearchActionMediumTest {
tester.get(IssueIndexer.class).indexAll();
WsTester.TestRequest request = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION);
- request.setParam(IssueFilterParameters.PAGE_INDEX, "2");
- request.setParam(IssueFilterParameters.PAGE_SIZE, "9");
+ request.setParam(PAGE_INDEX, "2");
+ request.setParam(PAGE_SIZE, "9");
WsTester.Result result = request.execute();
result.assertJson(this.getClass(), "deprecated_paging.json");
@@ -628,6 +634,31 @@ public class SearchActionMediumTest {
result.assertJson(this.getClass(), "default_page_size_is_100.json");
}
+ @Test
+ public void display_deprecated_debt_fields() throws Exception {
+ ComponentDto project = insertComponent(ComponentTesting.newProjectDto("PROJECT_ID").setKey("PROJECT_KEY"));
+ setDefaultProjectPermission(project);
+ ComponentDto file = insertComponent(ComponentTesting.newFileDto(project, "FILE_ID").setKey("FILE_KEY"));
+ IssueDto issue = IssueTesting.newDto(newRule(), file, project)
+ .setIssueCreationDate(DateUtils.parseDate("2014-09-04"))
+ .setIssueUpdateDate(DateUtils.parseDate("2017-12-04"))
+ .setEffort(10L)
+ .setStatus("OPEN")
+ .setKee("82fd47d4-b650-4037-80bc-7b112bd4eac2")
+ .setSeverity("MAJOR");
+ db.issueDao().insert(session, issue);
+ session.commit();
+ tester.get(IssueIndexer.class).indexAll();
+
+ userSessionRule.login("john");
+ WsTester.Result result = wsTester.newGetRequest(IssuesWs.API_ENDPOINT, SearchAction.SEARCH_ACTION)
+ .setParam("resolved", "false")
+ .setParam(WebService.Param.FACETS, "severities")
+ .setParam("facetMode", DEPRECATED_FACET_MODE_DEBT)
+ .execute();
+ result.assertJson(this.getClass(), "display_deprecated_debt_fields.json");
+ }
+
private RuleDto newRule() {
RuleDto rule = RuleTesting.newXooX1()
.setName("Rule name")
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/assigned_to_me_facet_sticky.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/assigned_to_me_facet_sticky.json
index 00e9e9f0c82..294b82ab004 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/assigned_to_me_facet_sticky.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/assigned_to_me_facet_sticky.json
@@ -6,7 +6,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min",
+ "effort": "10min",
"assignee": "alice"
}
],
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_deprecated_debt_fields.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_deprecated_debt_fields.json
new file mode 100644
index 00000000000..d3f950724f5
--- /dev/null
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_deprecated_debt_fields.json
@@ -0,0 +1,16 @@
+{
+ "debtTotal": 10,
+ "effortTotal": 10,
+ "issues": [
+ {
+ "key": "82fd47d4-b650-4037-80bc-7b112bd4eac2",
+ "component": "FILE_KEY",
+ "project": "PROJECT_KEY",
+ "rule": "xoo:x1",
+ "status": "OPEN",
+ "severity": "MAJOR",
+ "effort": "10min",
+ "debt": "10min"
+ }
+ ]
+}
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets.json
index 4a9a5fb36de..8cec05d3980 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets.json
@@ -6,7 +6,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min"
+ "effort": "10min"
}
],
"facets": [
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_debt.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_effort.json
index 2ce68b0381d..c71a31ef12f 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_debt.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_facets_effort.json
@@ -1,5 +1,5 @@
{
- "debtTotal": 10,
+ "effortTotal": 10,
"issues": [
{
"key": "82fd47d4-b650-4037-80bc-7b112bd4eac2",
@@ -8,7 +8,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min"
+ "effort": "10min"
}
],
"facets": [
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_zero_facets.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_zero_facets.json
index bdc015b144d..7b6d10d0f11 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_zero_facets.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/display_zero_facets.json
@@ -7,7 +7,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min"
+ "effort": "10min"
}
],
"facets": [
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/filter_by_assigned_to_me.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/filter_by_assigned_to_me.json
index f65f89b4974..4a0382aa7c1 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/filter_by_assigned_to_me.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/filter_by_assigned_to_me.json
@@ -7,7 +7,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min",
+ "effort": "10min",
"assignee": "john"
}
],
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/hide_rules.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/hide_rules.json
index 2c319af0b5a..e3c5691917f 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/hide_rules.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/hide_rules.json
@@ -7,7 +7,7 @@
"rule": "xoo:x1",
"status": "OPEN",
"severity": "MAJOR",
- "debt": "10min"
+ "effort": "10min"
}
],
"rules": []
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/response_contains_all_fields_except_additional_fields.json b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/response_contains_all_fields_except_additional_fields.json
index e88f5789021..a4abf93e3f6 100644
--- a/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/response_contains_all_fields_except_additional_fields.json
+++ b/server/sonar-server/src/test/resources/org/sonar/server/issue/ws/SearchActionMediumTest/response_contains_all_fields_except_additional_fields.json
@@ -8,7 +8,7 @@
"resolution": "FIXED",
"status": "RESOLVED",
"message": "the message",
- "debt": "10min",
+ "effort": "10min",
"assignee": "simon",
"reporter": "fabrice",
"author": "John",