]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-3437 Remove Measure from Hibernate model
authorJulien HENRY <julien.henry@sonarsource.com>
Thu, 24 Apr 2014 14:35:31 +0000 (16:35 +0200)
committerJulien HENRY <julien.henry@sonarsource.com>
Thu, 24 Apr 2014 15:22:05 +0000 (17:22 +0200)
sonar-batch/src/main/java/org/sonar/batch/index/MeasurePersister.java
sonar-core/src/main/resources/META-INF/persistence.xml
sonar-core/src/test/java/org/sonar/jpa/session/DatabaseSessionTest.java
sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureData.java
sonar-plugin-api/src/main/java/org/sonar/api/database/model/MeasureModel.java

index 80cac3ab4cb2ee7b398df4926a6b488a60ba5130..0512f5b1aa311e6f2eed72fa5c008001fb37bd1d 100644 (file)
@@ -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();
index 034e3dffd100c2ce9484b322e34aaa580645d147..79a9ad22f6bb6849a172d85f9cc815089425119b 100644 (file)
@@ -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>
index 99bb844283ed1d8a145ff418b52c88f91352f8f3..54d57081e68b453226a75caf1c3b6e5c5d65e8ac 100644 (file)
@@ -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;
@@ -49,25 +50,6 @@ public class DatabaseSessionTest extends AbstractDbUnitTestCase {
     project2 = new ResourceModel(ResourceModel.SCOPE_PROJECT, "mygroup:myartifact1", "JAV", null, "my name 2");
   }
 
-  @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"));
index b0275b64c393261aee4cf3ee465f27887bf8cb41..09b8f3b118a3ea6f5cbc5554478a9e9ed83f90ca 100644 (file)
@@ -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();
   }
 }
-
index f2a00deccfb58e5bea3a42ddb7be8bee4a85323b..795af64bb2715a3bd336417989881b8371fbcdf0 100644 (file)
@@ -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() {