aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/db/migrations/BaseSqlStatement.java4
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/db/migrations/MassUpdate.java7
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/db/migrations/Select.java3
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigration.java2
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/TechnicalDebtMeasuresMigration.java56
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/db/migrations/BaseDataChangeTest.java19
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest.java8
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist.xml12
-rw-r--r--server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist_result.xml12
9 files changed, 83 insertions, 40 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/BaseSqlStatement.java b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/BaseSqlStatement.java
index f04e2da2078..7992219f657 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/BaseSqlStatement.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/BaseSqlStatement.java
@@ -28,10 +28,10 @@ import java.sql.Timestamp;
import java.sql.Types;
import java.util.Date;
-abstract class BaseSqlStatement<CHILD extends SqlStatement> implements SqlStatement<CHILD> {
+class BaseSqlStatement<CHILD extends SqlStatement> implements SqlStatement<CHILD> {
protected PreparedStatement pstmt;
- BaseSqlStatement(PreparedStatement pstmt) {
+ protected BaseSqlStatement(PreparedStatement pstmt) {
this.pstmt = pstmt;
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/MassUpdate.java b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/MassUpdate.java
index 46e00c7eb62..8013d9cff81 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/MassUpdate.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/MassUpdate.java
@@ -34,6 +34,7 @@ public class MassUpdate {
public static interface Handler {
/**
* Convert some column values of a given row.
+ *
* @return true if the row must be updated, else false. If false, then the update parameter must not be touched.
*/
boolean handle(Select.Row row, SqlStatement update) throws SQLException;
@@ -99,8 +100,8 @@ public class MassUpdate {
}
static class ProgressTask extends TimerTask {
- static final long PERIOD_MS = 60000L;
- private final Logger logger = LoggerFactory.getLogger("DbMigration");
+ private static final Logger LOGGER = LoggerFactory.getLogger("DbMigration");
+ private static final long PERIOD_MS = 60000L;
private final AtomicLong counter;
private String rowName = "rows";
@@ -118,7 +119,7 @@ public class MassUpdate {
}
void log() {
- logger.info(String.format("%d %s processed", counter.get(), rowName));
+ LOGGER.info(String.format("%d %s processed", counter.get(), rowName));
}
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/Select.java b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/Select.java
index 57eb407d38a..a2307474d5d 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/Select.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/Select.java
@@ -74,7 +74,6 @@ public interface Select extends SqlStatement<Select> {
}
static interface RowReader<T> {
- RowReader<Long> LONG = new LongReader();
T read(Row row) throws SQLException;
}
@@ -88,6 +87,8 @@ public interface Select extends SqlStatement<Select> {
}
}
+ static final RowReader<Long> LONG_READER = new LongReader();
+
static interface RowHandler<T> {
void handle(Row row) throws SQLException;
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigration.java b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigration.java
index 5f419da982f..08746ac32c1 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigration.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigration.java
@@ -48,7 +48,7 @@ public class DevelopmentCostMeasuresMigration extends BaseDataChange {
public void execute(Context context) throws SQLException {
workDurationConvertor.init();
- Long metricId = context.prepareSelect("select id from metrics where name='development_cost'").get(Select.RowReader.LONG);
+ Long metricId = context.prepareSelect("select id from metrics where name='development_cost'").get(Select.LONG_READER);
if (metricId != null) {
MassUpdate massUpdate = context.prepareMassUpdate();
massUpdate.select("select id, value from project_measures where metric_id=? and value is not null").setLong(1, metricId);
diff --git a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/TechnicalDebtMeasuresMigration.java b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/TechnicalDebtMeasuresMigration.java
index 37a43d0ed2f..e5bf642069d 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/TechnicalDebtMeasuresMigration.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/db/migrations/v43/TechnicalDebtMeasuresMigration.java
@@ -55,7 +55,7 @@ public class TechnicalDebtMeasuresMigration extends BaseDataChange {
"where name='sqale_index' or name='new_technical_debt' " +
"or name='sqale_effort_to_grade_a' or name='sqale_effort_to_grade_b' or name='sqale_effort_to_grade_c' " +
"or name='sqale_effort_to_grade_d' or name='blocker_remediation_cost' or name='critical_remediation_cost' " +
- "or name='major_remediation_cost' or name='minor_remediation_cost' or name='info_remediation_cost'").list(Select.RowReader.LONG);
+ "or name='major_remediation_cost' or name='minor_remediation_cost' or name='info_remediation_cost'").list(Select.LONG_READER);
if (!metricIds.isEmpty()) {
MassUpdate massUpdate = context.prepareMassUpdate();
@@ -71,35 +71,37 @@ public class TechnicalDebtMeasuresMigration extends BaseDataChange {
}
massUpdate.update("UPDATE project_measures SET value=?," +
"variation_value_1=?,variation_value_2=?,variation_value_3=?,variation_value_4=?,variation_value_5=? WHERE id=?");
- massUpdate.execute(new MassUpdate.Handler() {
- @Override
- public boolean handle(Select.Row row, SqlStatement update) throws SQLException {
- Long id = row.getLong(1);
- Double value = row.getDouble(2);
- Double var1 = row.getDouble(3);
- Double var2 = row.getDouble(4);
- Double var3 = row.getDouble(5);
- Double var4 = row.getDouble(6);
- Double var5 = row.getDouble(7);
-
- update.setLong(1, convertDebtForDays(value));
- update.setLong(2, convertDebtForDays(var1));
- update.setLong(3, convertDebtForDays(var2));
- update.setLong(4, convertDebtForDays(var3));
- update.setLong(5, convertDebtForDays(var4));
- update.setLong(6, convertDebtForDays(var5));
- update.setLong(7, id);
- return true;
- }
- });
+ massUpdate.execute(new Converter());
}
}
- @CheckForNull
- private Long convertDebtForDays(@Nullable Double data) {
- if (data != null) {
- return workDurationConvertor.createFromDays(data);
+ private class Converter implements MassUpdate.Handler {
+ @Override
+ public boolean handle(Select.Row row, SqlStatement update) throws SQLException {
+ Long id = row.getLong(1);
+ Double value = row.getDouble(2);
+ Double var1 = row.getDouble(3);
+ Double var2 = row.getDouble(4);
+ Double var3 = row.getDouble(5);
+ Double var4 = row.getDouble(6);
+ Double var5 = row.getDouble(7);
+
+ update.setLong(1, convertDebtForDays(value));
+ update.setLong(2, convertDebtForDays(var1));
+ update.setLong(3, convertDebtForDays(var2));
+ update.setLong(4, convertDebtForDays(var3));
+ update.setLong(5, convertDebtForDays(var4));
+ update.setLong(6, convertDebtForDays(var5));
+ update.setLong(7, id);
+ return true;
+ }
+
+ @CheckForNull
+ private Long convertDebtForDays(@Nullable Double data) {
+ if (data != null) {
+ return workDurationConvertor.createFromDays(data);
+ }
+ return null;
}
- return null;
}
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/db/migrations/BaseDataChangeTest.java b/server/sonar-server/src/test/java/org/sonar/server/db/migrations/BaseDataChangeTest.java
index c8190fe267f..f34f3675c76 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/db/migrations/BaseDataChangeTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/db/migrations/BaseDataChangeTest.java
@@ -29,6 +29,7 @@ import org.sonar.core.persistence.TestDatabase;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
+import java.util.concurrent.atomic.AtomicBoolean;
import static org.fest.assertions.Assertions.assertThat;
import static org.fest.assertions.Fail.fail;
@@ -47,14 +48,20 @@ public class BaseDataChangeTest extends AbstractDaoTestCase {
public void query() throws Exception {
db.prepareDbUnit(getClass(), "persons.xml");
- final List<Long> ids = new ArrayList<Long>();
+ final AtomicBoolean executed = new AtomicBoolean(false);
new BaseDataChange(db.database()) {
@Override
public void execute(Context context) throws SQLException {
- ids.addAll(context.prepareSelect("select id from persons order by id desc").list(Select.RowReader.LONG));
+ assertThat(context.prepareSelect("select id from persons order by id desc").list(Select.LONG_READER))
+ .containsExactly(3L, 2L, 1L);
+ assertThat(context.prepareSelect("select id from persons where id=?").setLong(1, 2L).get(Select.LONG_READER))
+ .isEqualTo(2L);
+ assertThat(context.prepareSelect("select id from persons where id=?").setLong(1, 12345L).get(Select.LONG_READER))
+ .isNull();
+ executed.set(true);
}
}.execute();
- assertThat(ids).containsExactly(3L, 2L, 1L);
+ assertThat(executed.get()).isTrue();
}
@Test
@@ -87,7 +94,7 @@ public class BaseDataChangeTest extends AbstractDaoTestCase {
new BaseDataChange(db.database()) {
@Override
public void execute(Context context) throws SQLException {
- ids.addAll(context.prepareSelect("select id from persons where id>=?").setLong(1, 2L).list(Select.RowReader.LONG));
+ ids.addAll(context.prepareSelect("select id from persons where id>=?").setLong(1, 2L).list(Select.LONG_READER));
}
}.execute();
assertThat(ids).containsOnly(2L, 3L);
@@ -102,7 +109,7 @@ public class BaseDataChangeTest extends AbstractDaoTestCase {
@Override
public void execute(Context context) throws SQLException {
// parameter value is not set
- ids.addAll(context.prepareSelect("select id from persons where id>=?").list(Select.RowReader.LONG));
+ ids.addAll(context.prepareSelect("select id from persons where id>=?").list(Select.LONG_READER));
}
};
try {
@@ -332,7 +339,7 @@ public class BaseDataChangeTest extends AbstractDaoTestCase {
static class UserReader implements Select.RowReader<Object[]> {
@Override
public Object[] read(Select.Row row) throws SQLException {
- return new Object[] {
+ return new Object[]{
// id, login, age, enabled
row.getLong(1),
row.getString(2),
diff --git a/server/sonar-server/src/test/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest.java b/server/sonar-server/src/test/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest.java
index 5faeeba177f..2c4e061c3a3 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest.java
@@ -59,4 +59,12 @@ public class DevelopmentCostMeasuresMigrationTest {
db.assertDbUnit(getClass(), "migrate_dev_cost_measures_result.xml", "project_measures");
}
+ @Test
+ public void metric_does_not_exist() throws Exception {
+ db.prepareDbUnit(getClass(), "metric_does_not_exist.xml");
+
+ migration.execute();
+
+ db.assertDbUnit(getClass(), "metric_does_not_exist_result.xml", "project_measures");
+ }
}
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist.xml b/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist.xml
new file mode 100644
index 00000000000..0fb812f9a3d
--- /dev/null
+++ b/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist.xml
@@ -0,0 +1,12 @@
+<dataset>
+
+ <!-- ncloc -->
+ <metrics delete_historical_data="[null]" id="1" name="ncloc" VAL_TYPE="STRING" DESCRIPTION="[null]" domain="[null]" short_name=""
+ enabled="true" worst_value="[null]" optimized_best_value="[null]" best_value="[null]" direction="0" hidden="false"/>
+
+ <project_measures id="1" VALUE="1.0" METRIC_ID="1" SNAPSHOT_ID="1000" alert_text="[null]" RULES_CATEGORY_ID="[null]"
+ RULE_ID="[null]" text_value="[null]" tendency="[null]" measure_date="[null]" project_id="[null]"
+ alert_status="[null]" description="[null]" rule_priority="[null]" characteristic_id="[null]" url="[null]" person_id="[null]"
+ variation_value_1="[null]" variation_value_2="[null]" variation_value_3="[null]" variation_value_4="[null]" variation_value_5="[null]"/>
+
+</dataset>
diff --git a/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist_result.xml b/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist_result.xml
new file mode 100644
index 00000000000..0fb812f9a3d
--- /dev/null
+++ b/server/sonar-server/src/test/resources/org/sonar/server/db/migrations/v43/DevelopmentCostMeasuresMigrationTest/metric_does_not_exist_result.xml
@@ -0,0 +1,12 @@
+<dataset>
+
+ <!-- ncloc -->
+ <metrics delete_historical_data="[null]" id="1" name="ncloc" VAL_TYPE="STRING" DESCRIPTION="[null]" domain="[null]" short_name=""
+ enabled="true" worst_value="[null]" optimized_best_value="[null]" best_value="[null]" direction="0" hidden="false"/>
+
+ <project_measures id="1" VALUE="1.0" METRIC_ID="1" SNAPSHOT_ID="1000" alert_text="[null]" RULES_CATEGORY_ID="[null]"
+ RULE_ID="[null]" text_value="[null]" tendency="[null]" measure_date="[null]" project_id="[null]"
+ alert_status="[null]" description="[null]" rule_priority="[null]" characteristic_id="[null]" url="[null]" person_id="[null]"
+ variation_value_1="[null]" variation_value_2="[null]" variation_value_3="[null]" variation_value_4="[null]" variation_value_5="[null]"/>
+
+</dataset>