aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulien HENRY <julien.henry@sonarsource.com>2014-04-24 16:35:31 +0200
committerJulien HENRY <julien.henry@sonarsource.com>2014-04-24 17:22:05 +0200
commitcafd76d5317716817c0f15a402d820a6e80d19a9 (patch)
treec5fca19f9e94153e942b038307093543b5dd3f46
parent0deff2ed59b0e254cb0a5be460d0faab0aa97b23 (diff)
downloadsonarqube-cafd76d5317716817c0f15a402d820a6e80d19a9.tar.gz
sonarqube-cafd76d5317716817c0f15a402d820a6e80d19a9.zip
SONAR-3437 Remove Measure from Hibernate model
-rw-r--r--sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java1
-rw-r--r--sonar-core/src/main/resources/META-INF/persistence.xml2
-rw-r--r--sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java34
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java21
-rw-r--r--sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java52
5 files changed, 24 insertions, 86 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java b/sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java
index 80cac3ab4cb..0512f5b1aa3 100644
--- a/sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java
+++ b/sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java
@@ -58,7 +58,6 @@ public final class MeasurePersister implements ScanPersister {
SqlSession session = mybatis.openSession();
try {
MeasureMapper mapper = session.getMapper(MeasureMapper.class);
-
for (Entry<Measure> entry : measureCache.entries()) {
String effectiveKey = entry.key()[0].toString();
Measure measure = entry.value();
diff --git a/sonar-core/src/main/resources/META-INF/persistence.xml b/sonar-core/src/main/resources/META-INF/persistence.xml
index 034e3dffd10..79a9ad22f6b 100644
--- a/sonar-core/src/main/resources/META-INF/persistence.xml
+++ b/sonar-core/src/main/resources/META-INF/persistence.xml
@@ -11,8 +11,6 @@
<class>org.sonar.api.database.configuration.Property</class>
<class>org.sonar.api.database.model.User</class>
<class>org.sonar.api.database.model.Snapshot</class>
- <class>org.sonar.api.database.model.MeasureModel</class>
- <class>org.sonar.api.database.model.MeasureData</class>
<class>org.sonar.api.design.DependencyDto</class>
<class>org.sonar.api.measures.Metric</class>
<class>org.sonar.api.database.model.ResourceModel</class>
diff --git a/sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java b/sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java
index 99bb844283e..54d57081e68 100644
--- a/sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java
+++ b/sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java
@@ -23,19 +23,20 @@ import org.hamcrest.Matchers;
import org.junit.Before;
import org.junit.Test;
import org.junit.internal.matchers.IsCollectionContaining;
-import org.sonar.api.database.model.MeasureModel;
import org.sonar.api.database.model.ResourceModel;
-import org.sonar.api.database.model.Snapshot;
-import org.sonar.api.measures.CoreMetrics;
-import org.sonar.api.measures.Metric;
-import org.sonar.jpa.dao.MeasuresDao;
import org.sonar.jpa.test.AbstractDbUnitTestCase;
import javax.persistence.NonUniqueResultException;
-import java.sql.Date;
+
import java.util.List;
-import static org.junit.Assert.*;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertNull;
+import static org.junit.Assert.assertThat;
+import static org.junit.Assert.assertTrue;
+import static org.junit.Assert.fail;
public class DatabaseSessionTest extends AbstractDbUnitTestCase {
private static final Long NB_INSERTS = 20000l;
@@ -50,25 +51,6 @@ public class DatabaseSessionTest extends AbstractDbUnitTestCase {
}
@Test
- public void performanceTestOnBatchInserts() throws Exception {
- getSession().save(project1);
- Snapshot snapshot = new Snapshot(project1, true, "", new Date(1));
- getSession().save(snapshot);
- getSession().save(CoreMetrics.CLASSES);
- getSession().commit();
-
- Metric metric = new MeasuresDao(getSession()).getMetric(CoreMetrics.CLASSES_KEY);
- for (int i = 0; i < NB_INSERTS; i++) {
- MeasureModel pm = new MeasureModel(metric.getId(), 1.0).setSnapshotId(snapshot.getId());
- getSession().save(pm);
- }
-
- getSession().commit();
- assertEquals(NB_INSERTS, getHQLCount(MeasureModel.class));
-
- }
-
- @Test
public void testGetSingleResultWithNoResults() {
assertNull(getSession().getSingleResult(ResourceModel.class, "name", "test"));
}
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java b/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java
index b0275b64c39..09b8f3b118a 100644
--- a/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java
+++ b/sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java
@@ -23,23 +23,17 @@ import com.google.common.base.Charsets;
import com.google.common.base.Throwables;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
-import org.sonar.api.database.BaseIdentifiable;
-import javax.persistence.*;
import java.io.UnsupportedEncodingException;
-@Entity
-@Table(name = "measure_data")
-public class MeasureData extends BaseIdentifiable {
+public class MeasureData {
+
+ private Integer id;
- @OneToOne(fetch = FetchType.LAZY)
- @JoinColumn(name = "measure_id")
private MeasureModel measure;
- @Column(name = "snapshot_id", updatable = true, nullable = true)
private Integer snapshotId;
- @Column(name = "data", updatable = true, nullable = true, length = 167772150)
private byte[] data;
public MeasureData(MeasureModel measure) {
@@ -59,6 +53,14 @@ public class MeasureData extends BaseIdentifiable {
public MeasureData() {
}
+ public Integer getId() {
+ return id;
+ }
+
+ public void setId(Integer id) {
+ this.id = id;
+ }
+
public MeasureModel getMeasure() {
return measure;
}
@@ -104,4 +106,3 @@ public class MeasureData extends BaseIdentifiable {
.toString();
}
}
-
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 f2a00deccfb..795af64bb27 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
@@ -25,96 +25,62 @@ import org.sonar.api.database.DatabaseSession;
import org.sonar.api.measures.Metric;
import org.sonar.api.rules.RulePriority;
-import javax.persistence.*;
-
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
-/**
- * This class is the Hibernate model to store a measure in the DB
- */
-@Entity
-@Table(name = "project_measures")
public class MeasureModel implements Cloneable {
public static final int TEXT_VALUE_LENGTH = 96;
- @Id
- @Column(name = "id")
- @GeneratedValue
private Long id;
- @Column(name = "value", updatable = true, nullable = true, precision = 30, scale = 20)
private Double value = 0.0;
- @Column(name = "text_value", updatable = true, nullable = true, length = TEXT_VALUE_LENGTH)
private String textValue;
- @Column(name = "tendency", updatable = true, nullable = true)
private Integer tendency;
- @Column(name = "metric_id", updatable = false, nullable = false)
private Integer metricId;
- @Column(name = "snapshot_id", updatable = true, nullable = true)
private Integer snapshotId;
- @Column(name = "project_id", updatable = true, nullable = true)
private Integer projectId;
- @Column(name = "description", updatable = true, nullable = true, length = 4000)
private String description;
- @Temporal(TemporalType.TIMESTAMP)
- @Column(name = "measure_date", updatable = true, nullable = true)
private Date measureDate;
- @Column(name = "rule_id", updatable = true, nullable = true)
private Integer ruleId;
/**
* @deprecated since 2.5 See http://jira.codehaus.org/browse/SONAR-2007
*/
@Deprecated
- @Column(name = "rules_category_id", nullable = true)
- private Integer rulesCategoryId;//NOSONAR this field is kept for backward-compatiblity of API
+ private Integer rulesCategoryId;// NOSONAR this field is kept for backward-compatiblity of API
- @Column(name = "rule_priority", updatable = false, nullable = true)
- @Enumerated(EnumType.ORDINAL)
private RulePriority rulePriority;
- @Column(name = "alert_status", updatable = true, nullable = true, length = 5)
private String alertStatus;
- @Column(name = "alert_text", updatable = true, nullable = true, length = 4000)
private String alertText;
- @Column(name = "variation_value_1", updatable = true, nullable = true)
private Double variationValue1;
- @Column(name = "variation_value_2", updatable = true, nullable = true)
private Double variationValue2;
- @Column(name = "variation_value_3", updatable = true, nullable = true)
private Double variationValue3;
- @Column(name = "variation_value_4", updatable = true, nullable = true)
private Double variationValue4;
- @Column(name = "variation_value_5", updatable = true, nullable = true)
private Double variationValue5;
- @Column(name = "url", updatable = true, nullable = true, length = 2000)
private String url;
- @OneToMany(mappedBy = "measure", fetch = FetchType.LAZY, cascade = {CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REMOVE})
private List<MeasureData> measureData = new ArrayList<MeasureData>();
- @Column(name = "characteristic_id", nullable = true)
private Integer characteristicId;
- @Column(name = "person_id", updatable = true, nullable = true)
private Integer personId;
public Long getId() {
@@ -395,7 +361,7 @@ public class MeasureModel implements Cloneable {
/**
* Use setData() instead
*/
- //@Deprecated
+ // @Deprecated
public void setMeasureData(MeasureData data) {
measureData.clear();
if (data != null) {
@@ -480,19 +446,11 @@ public class MeasureModel implements Cloneable {
* Saves the current object to database
*
* @return the current object
+ * @deprecated since 4.4 We don't use Hibernate anymore. See {@link MeasureMapper}.
*/
+ @Deprecated
public MeasureModel save(DatabaseSession session) {
- MeasureData data = getMeasureData();
- setMeasureData(null);
- session.save(this);
-
- if (data != null) {
- data.setMeasure(session.getEntity(MeasureModel.class, getId()));
- data.setSnapshotId(snapshotId);
- session.save(data);
- setMeasureData(data);
- }
- return this;
+ throw new UnsupportedOperationException();
}
public Integer getCharacteristicId() {