diff options
author | Julien Lancelot <julien.lancelot@sonarsource.com> | 2015-03-18 09:17:50 +0100 |
---|---|---|
committer | Julien Lancelot <julien.lancelot@sonarsource.com> | 2015-03-18 09:18:46 +0100 |
commit | 8f376a0a64dac99cfddfafcded66445997a65670 (patch) | |
tree | c85216945eef38babfc84a77daec32c0077b27c5 /sonar-plugin-api | |
parent | dd574e51443d8c9dc64aa7d889f7f6f1281d9ec5 (diff) | |
parent | d8bc34c28c0b81ad685ac66e63e362a7ed29e8a1 (diff) | |
download | sonarqube-8f376a0a64dac99cfddfafcded66445997a65670.tar.gz sonarqube-8f376a0a64dac99cfddfafcded66445997a65670.zip |
Merge branch-5.1
Diffstat (limited to 'sonar-plugin-api')
4 files changed, 23 insertions, 45 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java b/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java index dc5847f7564..fdf32504847 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java @@ -30,10 +30,6 @@ import org.sonar.api.rules.RulePriority; import javax.persistence.*; import java.io.UnsupportedEncodingException; -import java.util.Date; - -import static org.sonar.api.utils.DateUtils.dateToLong; -import static org.sonar.api.utils.DateUtils.longToDate; /** * This class is the Hibernate model to store a measure in the DB @@ -70,9 +66,6 @@ public class MeasureModel implements Cloneable { @Column(name = "description", updatable = true, nullable = true, length = 4000) private String description; - @Column(name = "measure_date", updatable = true, nullable = true) - private Long measureDate; - @Column(name = "rule_id", updatable = true, nullable = true) private Integer ruleId; @@ -306,40 +299,6 @@ public class MeasureModel implements Cloneable { } /** - * @return the date of the measure - */ - public Date getMeasureDate() { - return longToDate(measureDate); - } - - /** - * Sets the date for the measure - * - * @return the current object - */ - public MeasureModel setMeasureDate(Date measureDate) { - this.measureDate = dateToLong(measureDate); - return this; - } - - /** - * @return the date of the measure - */ - public Long getMeasureDateMs() { - return measureDate; - } - - /** - * Sets the date for the measure - * - * @return the current object - */ - public MeasureModel setMeasureDateMs(Long measureDate) { - this.measureDate = measureDate; - return this; - } - - /** * @return the alert status if there is one, null otherwise */ public Metric.Level getAlertStatus() { @@ -519,7 +478,6 @@ public class MeasureModel implements Cloneable { clone.setRulePriority(getRulePriority()); clone.setRuleId(getRuleId()); clone.setSnapshotId(getSnapshotId()); - clone.setMeasureDate(getMeasureDate()); clone.setUrl(getUrl()); clone.setCharacteristicId(getCharacteristicId()); clone.setPersonId(getPersonId()); diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/utils/text/JsonWriter.java b/sonar-plugin-api/src/main/java/org/sonar/api/utils/text/JsonWriter.java index f8645826374..8d231bcc1a5 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/utils/text/JsonWriter.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/utils/text/JsonWriter.java @@ -22,6 +22,7 @@ package org.sonar.api.utils.text; import org.sonar.api.utils.DateUtils; import javax.annotation.Nullable; + import java.io.Writer; import java.util.Date; import java.util.Map; @@ -69,6 +70,11 @@ public class JsonWriter { return new JsonWriter(writer); } + public JsonWriter setSerializeNulls(boolean b) { + this.stream.setSerializeNulls(b); + return this; + } + /** * Begins encoding a new array. Each call to this method must be paired with * a call to {@link #endArray}. Output is <code>[</code>. diff --git a/sonar-plugin-api/src/main/resources/org/sonar/api/database/model/MeasureMapper.xml b/sonar-plugin-api/src/main/resources/org/sonar/api/database/model/MeasureMapper.xml index 66b00baacae..1bf6e453f64 100644 --- a/sonar-plugin-api/src/main/resources/org/sonar/api/database/model/MeasureMapper.xml +++ b/sonar-plugin-api/src/main/resources/org/sonar/api/database/model/MeasureMapper.xml @@ -5,12 +5,12 @@ <insert id="insert" parameterType="MeasureModel" useGeneratedKeys="false"> INSERT INTO project_measures ( - value, metric_id, snapshot_id, rule_id, text_value, tendency, measure_date, + value, metric_id, snapshot_id, rule_id, text_value, tendency, project_id, alert_status, alert_text, url, description, rule_priority, characteristic_id, variation_value_1, variation_value_2, variation_value_3, variation_value_4, variation_value_5, person_id, measure_data) VALUES ( #{value, jdbcType=DOUBLE}, #{metricId, jdbcType=INTEGER}, #{snapshotId, jdbcType=INTEGER}, #{ruleId, jdbcType=INTEGER}, #{textValue, jdbcType=VARCHAR}, #{tendency, jdbcType=INTEGER}, - #{measureDateMs, jdbcType=BIGINT}, #{projectId, jdbcType=INTEGER}, #{alertStatus, jdbcType=VARCHAR}, #{alertText, jdbcType=VARCHAR}, + #{projectId, jdbcType=INTEGER}, #{alertStatus, jdbcType=VARCHAR}, #{alertText, jdbcType=VARCHAR}, #{url, jdbcType=VARCHAR}, #{description, jdbcType=VARCHAR}, #{rulePriority.ordinal, jdbcType=INTEGER}, #{characteristicId, jdbcType=INTEGER}, #{variationValue1, jdbcType=DOUBLE}, #{variationValue2, jdbcType=DOUBLE}, #{variationValue3, jdbcType=DOUBLE}, #{variationValue4, jdbcType=DOUBLE}, #{variationValue5, jdbcType=DOUBLE}, #{personId, jdbcType=INTEGER}, #{data} ) diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/utils/text/JsonWriterTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/utils/text/JsonWriterTest.java index 45280508abb..f0de3de0434 100644 --- a/sonar-plugin-api/src/test/java/org/sonar/api/utils/text/JsonWriterTest.java +++ b/sonar-plugin-api/src/test/java/org/sonar/api/utils/text/JsonWriterTest.java @@ -101,7 +101,7 @@ public class JsonWriterTest { } @Test - public void ignore_null_values() throws Exception { + public void ignore_null_values_by_default() throws Exception { writer.beginObject() .prop("nullNumber", (Number) null) .prop("nullString", (String) null) @@ -114,6 +114,20 @@ public class JsonWriterTest { } @Test + public void serialize_null_values() throws Exception { + writer.setSerializeNulls(true); + writer.beginObject() + .prop("nullNumber", (Number) null) + .prop("nullString", (String) null) + .name("nullNumber").value((Number) null) + .name("nullString").value((String) null) + .name("nullDate").valueDate(null) + .name("nullDateTime").valueDate(null) + .endObject().close(); + expect("{\"nullNumber\":null,\"nullString\":null,\"nullNumber\":null,\"nullString\":null,\"nullDate\":null,\"nullDateTime\":null}"); + } + + @Test public void escape_values() throws Exception { writer.beginObject() .prop("foo", "<hello \"world\">") |