From 4e76eae61a9cc708dde1e71d1895dfbb810f63ce Mon Sep 17 00:00:00 2001 From: Michal Duda Date: Thu, 11 Mar 2021 20:52:24 +0100 Subject: SONAR-14192 Add optional return field 'deprecatedKeys' to /api/rules/search --- .../org/sonar/scanner/rule/DefaultActiveRulesLoader.java | 12 +++++++++--- .../java/org/sonar/scanner/rule/ActiveRulesProviderTest.java | 2 ++ .../org/sonar/scanner/rule/DefaultActiveRulesLoaderTest.java | 2 +- 3 files changed, 12 insertions(+), 4 deletions(-) (limited to 'sonar-scanner-engine') diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/rule/DefaultActiveRulesLoader.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/rule/DefaultActiveRulesLoader.java index 192ddf208ad..6404d8184dc 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/rule/DefaultActiveRulesLoader.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/rule/DefaultActiveRulesLoader.java @@ -25,12 +25,13 @@ import java.util.HashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; +import java.util.stream.Collectors; import org.apache.commons.io.IOUtils; -import org.sonar.scanner.bootstrap.ScannerWsClient; -import org.sonar.api.impl.utils.ScannerUtils; import org.sonar.api.batch.rule.LoadedActiveRule; +import org.sonar.api.impl.utils.ScannerUtils; import org.sonar.api.rule.RuleKey; import org.sonar.api.utils.DateUtils; +import org.sonar.scanner.bootstrap.ScannerWsClient; import org.sonarqube.ws.Rules; import org.sonarqube.ws.Rules.Active; import org.sonarqube.ws.Rules.Active.Param; @@ -40,7 +41,8 @@ import org.sonarqube.ws.Rules.SearchResponse; import org.sonarqube.ws.client.GetRequest; public class DefaultActiveRulesLoader implements ActiveRulesLoader { - private static final String RULES_SEARCH_URL = "/api/rules/search.protobuf?f=repo,name,severity,lang,internalKey,templateKey,params,actives,createdAt,updatedAt&activation=true"; + private static final String RULES_SEARCH_URL = "/api/rules/search.protobuf?" + + "f=repo,name,severity,lang,internalKey,templateKey,params,actives,createdAt,updatedAt,deprecatedKeys&activation=true"; private final ScannerWsClient wsClient; @@ -125,6 +127,10 @@ public class DefaultActiveRulesLoader implements ActiveRulesLoader { params.put(param.getKey(), param.getValue()); } loadedRule.setParams(params); + loadedRule.setDeprecatedKeys(r.getDeprecatedKeys().getDeprecatedKeyList() + .stream() + .map(RuleKey::parse) + .collect(Collectors.toSet())); loadedRules.add(loadedRule); } diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/ActiveRulesProviderTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/ActiveRulesProviderTest.java index 77536daacaa..0f1aef9124d 100644 --- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/ActiveRulesProviderTest.java +++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/ActiveRulesProviderTest.java @@ -21,6 +21,7 @@ package org.sonar.scanner.rule; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; +import com.google.common.collect.ImmutableSet; import java.util.Date; import java.util.LinkedList; import java.util.List; @@ -116,6 +117,7 @@ public class ActiveRulesProviderTest { LoadedActiveRule r = new LoadedActiveRule(); r.setName(name); r.setRuleKey(RuleKey.of(name, name)); + r.setDeprecatedKeys(ImmutableSet.of(RuleKey.of(name + "old", name + "old"))); return r; } } diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/DefaultActiveRulesLoaderTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/DefaultActiveRulesLoaderTest.java index cdc32114402..e823ddf3bfa 100644 --- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/DefaultActiveRulesLoaderTest.java +++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/rule/DefaultActiveRulesLoaderTest.java @@ -91,7 +91,7 @@ public class DefaultActiveRulesLoaderTest { } private String urlOfPage(int page) { - return "/api/rules/search.protobuf?f=repo,name,severity,lang,internalKey,templateKey,params,actives,createdAt,updatedAt&activation=true" + return "/api/rules/search.protobuf?f=repo,name,severity,lang,internalKey,templateKey,params,actives,createdAt,updatedAt,deprecatedKeys&activation=true" + ("") + "&qprofile=c%2B-test_c%2B-values-17445&ps=500&p=" + page + ""; } -- cgit v1.2.3