aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-ws-client/src/main/java/org/sonar/wsclient/issue/IssueChangeDiff.java4
-rw-r--r--sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssue.java2
-rw-r--r--sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssueChangeDiff.java25
-rw-r--r--sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultTechnicalDebt.java3
-rw-r--r--sonar-ws-client/src/test/java/org/sonar/wsclient/issue/internal/IssueJsonParserTest.java42
-rw-r--r--sonar-ws-client/src/test/resources/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-only-new-technical-debt.json20
6 files changed, 83 insertions, 13 deletions
diff --git a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/IssueChangeDiff.java b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/IssueChangeDiff.java
index 364b9fb9fce..7ab2fdce49f 100644
--- a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/IssueChangeDiff.java
+++ b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/IssueChangeDiff.java
@@ -29,9 +29,9 @@ public interface IssueChangeDiff {
String key();
@CheckForNull
- String newValue();
+ Object newValue();
@CheckForNull
- String oldValue();
+ Object oldValue();
}
diff --git a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssue.java b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssue.java
index 50c74c34a08..652decf37f2 100644
--- a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssue.java
+++ b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssue.java
@@ -79,7 +79,7 @@ public class DefaultIssue implements Issue {
@CheckForNull
public TechnicalDebt technicalDebt() {
- Map technicalDebt = (Map) json.get("technicalDebt");
+ Map technicalDebt = (Map) json.get(DefaultTechnicalDebt.KEY);
if (technicalDebt != null) {
return new DefaultTechnicalDebt(technicalDebt);
}
diff --git a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssueChangeDiff.java b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssueChangeDiff.java
index 0454267e920..2f57f46653d 100644
--- a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssueChangeDiff.java
+++ b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultIssueChangeDiff.java
@@ -42,13 +42,30 @@ public class DefaultIssueChangeDiff implements IssueChangeDiff {
}
@CheckForNull
- public String newValue() {
- return JsonUtils.getString(json, "newValue");
+ public Object newValue() {
+ return parseValue("newValue");
+
}
@CheckForNull
- public String oldValue() {
- return JsonUtils.getString(json, "oldValue");
+ public Object oldValue() {
+ return parseValue("oldValue");
+ }
+
+ private Object parseValue(String attribute) {
+ if (DefaultTechnicalDebt.KEY.equals(key())) {
+ return parseDefaultTechnicalDebt(attribute);
+ } else {
+ return JsonUtils.getString(json, attribute);
+ }
+ }
+
+ private DefaultTechnicalDebt parseDefaultTechnicalDebt(String attribute){
+ Map technicalDebt = (Map) json.get(attribute);
+ if (technicalDebt != null) {
+ return new DefaultTechnicalDebt(technicalDebt);
+ }
+ return null;
}
}
diff --git a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultTechnicalDebt.java b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultTechnicalDebt.java
index 5bd45d915a9..9bdab493bf7 100644
--- a/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultTechnicalDebt.java
+++ b/sonar-ws-client/src/main/java/org/sonar/wsclient/issue/internal/DefaultTechnicalDebt.java
@@ -28,6 +28,9 @@ import java.util.Map;
* @since 4.0
*/
public class DefaultTechnicalDebt implements TechnicalDebt {
+
+ public static final String KEY = "technicalDebt";
+
private final Map json;
DefaultTechnicalDebt(Map json) {
diff --git a/sonar-ws-client/src/test/java/org/sonar/wsclient/issue/internal/IssueJsonParserTest.java b/sonar-ws-client/src/test/java/org/sonar/wsclient/issue/internal/IssueJsonParserTest.java
index 87f86d26c4e..4acc0bf370e 100644
--- a/sonar-ws-client/src/test/java/org/sonar/wsclient/issue/internal/IssueJsonParserTest.java
+++ b/sonar-ws-client/src/test/java/org/sonar/wsclient/issue/internal/IssueJsonParserTest.java
@@ -20,7 +20,6 @@
package org.sonar.wsclient.issue.internal;
import org.apache.commons.io.IOUtils;
-import org.junit.Ignore;
import org.junit.Test;
import org.sonar.wsclient.base.Paging;
import org.sonar.wsclient.component.Component;
@@ -242,7 +241,6 @@ public class IssueJsonParserTest {
}
@Test
- @Ignore
public void should_parse_changelog_with_technical_debt() throws Exception {
String json = IOUtils.toString(getClass().getResourceAsStream("/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-technical-debt.json"));
List<IssueChange> changes = new IssueJsonParser().parseChangelog(json);
@@ -254,10 +252,42 @@ public class IssueJsonParserTest {
assertThat(change.updatedAt().getTime()).isEqualTo(1383202235000l);
assertThat(change.diffs()).hasSize(1);
- IssueChangeDiff diffChange1 = change.diffs().get(0);
- assertThat(diffChange1.key()).isEqualTo("technicalDebt");
- assertThat(diffChange1.newValue()).isEqualTo("1.0");
- assertThat(diffChange1.oldValue()).isNull();
+ IssueChangeDiff changeDiff = change.diffs().get(0);
+ assertThat(changeDiff.key()).isEqualTo("technicalDebt");
+
+ TechnicalDebt newTechnicalDebt = (TechnicalDebt) changeDiff.newValue();
+ assertThat(newTechnicalDebt.days()).isEqualTo(2);
+ assertThat(newTechnicalDebt.hours()).isEqualTo(1);
+ assertThat(newTechnicalDebt.minutes()).isEqualTo(0);
+
+ TechnicalDebt oldTechnicalDebt = (TechnicalDebt) changeDiff.oldValue();
+ assertThat(oldTechnicalDebt.days()).isEqualTo(3);
+ assertThat(oldTechnicalDebt.hours()).isEqualTo(0);
+ assertThat(oldTechnicalDebt.minutes()).isEqualTo(10);
+ }
+
+ @Test
+ public void should_parse_changelog_with_only_new_technical_debt() throws Exception {
+ String json = IOUtils.toString(getClass().getResourceAsStream("/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-only-new-technical-debt.json"));
+ List<IssueChange> changes = new IssueJsonParser().parseChangelog(json);
+
+ assertThat(changes).hasSize(1);
+ IssueChange change = changes.get(0);
+ assertThat(change.user()).isEqualTo("julien");
+ assertThat(change.createdAt().getTime()).isEqualTo(1383202235000l);
+ assertThat(change.updatedAt().getTime()).isEqualTo(1383202235000l);
+
+ assertThat(change.diffs()).hasSize(1);
+ IssueChangeDiff changeDiff = change.diffs().get(0);
+ assertThat(changeDiff.key()).isEqualTo("technicalDebt");
+
+ TechnicalDebt newTechnicalDebt = (TechnicalDebt) changeDiff.newValue();
+ assertThat(newTechnicalDebt.days()).isEqualTo(2);
+ assertThat(newTechnicalDebt.hours()).isEqualTo(1);
+ assertThat(newTechnicalDebt.minutes()).isEqualTo(0);
+
+ TechnicalDebt oldTechnicalDebt = (TechnicalDebt) changeDiff.oldValue();
+ assertThat(oldTechnicalDebt).isNull();
}
@Test
diff --git a/sonar-ws-client/src/test/resources/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-only-new-technical-debt.json b/sonar-ws-client/src/test/resources/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-only-new-technical-debt.json
new file mode 100644
index 00000000000..174513f5a5d
--- /dev/null
+++ b/sonar-ws-client/src/test/resources/org/sonar/wsclient/issue/internal/IssueJsonParserTest/changelog-with-only-new-technical-debt.json
@@ -0,0 +1,20 @@
+{
+ "changelog": [
+ {
+ "user": "julien",
+ "createdAt": "2013-10-31T07:50:35+0100",
+ "updatedAt": "2013-10-31T07:50:35+0100",
+ "diffs": [
+ {
+ "key": "technicalDebt",
+ "newValue": {
+ "days": 2,
+ "hours": 1,
+ "minutes": 0
+ }
+ }
+ ]
+ }
+ ]
+}
+