diff options
3 files changed, 51 insertions, 35 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/components/TimeMachineConfiguration.java b/sonar-batch/src/main/java/org/sonar/batch/components/TimeMachineConfiguration.java index ea5889dd2e9..bb8be2a2947 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/components/TimeMachineConfiguration.java +++ b/sonar-batch/src/main/java/org/sonar/batch/components/TimeMachineConfiguration.java @@ -67,6 +67,10 @@ public class TimeMachineConfiguration implements BatchExtension { } } + /** + * Only used to get the real date of the snapshot on the current period. + * The date is used to calculate new_violations measures + */ @CheckForNull private Snapshot findSnapshot(Snapshot projectSnapshot) { String hql = "from " + Snapshot.class.getSimpleName() + " where resourceId=:resourceId and (rootId=:rootSnapshotId or id=:rootSnapshotId)"; @@ -75,7 +79,6 @@ public class TimeMachineConfiguration implements BatchExtension { .setParameter("rootSnapshotId", projectSnapshot.getId()) .setMaxResults(1) .getResultList(); - return snapshots.isEmpty() ? null : snapshots.get(0); } diff --git a/sonar-batch/src/test/java/org/sonar/batch/components/TimeMachineConfigurationTest.java b/sonar-batch/src/test/java/org/sonar/batch/components/TimeMachineConfigurationTest.java index c2d0e0b2beb..ca2b553060c 100644 --- a/sonar-batch/src/test/java/org/sonar/batch/components/TimeMachineConfigurationTest.java +++ b/sonar-batch/src/test/java/org/sonar/batch/components/TimeMachineConfigurationTest.java @@ -20,8 +20,8 @@ package org.sonar.batch.components; import org.junit.Before; -import org.junit.Ignore; import org.junit.Test; +import org.sonar.api.database.model.Snapshot; import org.sonar.api.resources.Project; import org.sonar.jpa.test.AbstractDbUnitTestCase; @@ -38,62 +38,72 @@ public class TimeMachineConfigurationTest extends AbstractDbUnitTestCase { @Before public void before() { + setupData("shared"); periodsDefinition = mock(PeriodsDefinition.class); } @Test - @Ignore - public void get_module_past_snapshot() { - Integer projectId = 1; - Date targetDate = new Date(); + public void get_project_past_snapshot() { + Snapshot projectSnapshot = new Snapshot(); + projectSnapshot.setId(1010); + PastSnapshot projectPastSnapshot = new PastSnapshot("mode", new Date(), projectSnapshot); + + when(periodsDefinition.getRootProjectPastSnapshots()).thenReturn(newArrayList(projectPastSnapshot)); - PastSnapshot projectPastSnapshot = new PastSnapshot("mode", targetDate); - PastSnapshot modulePastSnapshot = new PastSnapshot("mode", targetDate); + TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(getSession(), (Project) new Project("my:project").setId(1), periodsDefinition); + assertThat(timeMachineConfiguration.periods()).hasSize(1); + assertThat(timeMachineConfiguration.periods().get(0).getDate()).isNotNull(); + assertThat(timeMachineConfiguration.getProjectPastSnapshots()).hasSize(1); + assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getProjectSnapshot().getId()).isEqualTo(1010); + } + + @Test + public void get_module_past_snapshot() { + Snapshot projectSnapshot = new Snapshot(); + projectSnapshot.setId(1010); + PastSnapshot projectPastSnapshot = new PastSnapshot("mode", new Date(), projectSnapshot); when(periodsDefinition.getRootProjectPastSnapshots()).thenReturn(newArrayList(projectPastSnapshot)); - //when(pastSnapshotFinderByDate.findByDate(anyInt(), any(Date.class))).thenReturn(modulePastSnapshot); - TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(null, (Project) new Project("my:project").setId(projectId), periodsDefinition); + TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(getSession(), (Project) new Project("my:module").setId(2), periodsDefinition); assertThat(timeMachineConfiguration.periods()).hasSize(1); + assertThat(timeMachineConfiguration.periods().get(0).getDate()).isNotNull(); assertThat(timeMachineConfiguration.getProjectPastSnapshots()).hasSize(1); + assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getProjectSnapshot().getId()).isEqualTo(1010); } @Test - @Ignore - public void complete_module_past_snapshot_from_project_past_snapshot() { - Integer projectId = 1; - Date targetDate = new Date(); + public void complete_past_snapshot_from_project_past_snapshot() { + Snapshot projectSnapshot = new Snapshot(); + projectSnapshot.setId(1010); - PastSnapshot projectPastSnapshot = new PastSnapshot("mode", targetDate); + PastSnapshot projectPastSnapshot = new PastSnapshot("mode", new Date(), projectSnapshot); projectPastSnapshot.setIndex(1); projectPastSnapshot.setMode("mode"); projectPastSnapshot.setModeParameter("modeParam"); - PastSnapshot modulePastSnapshot = new PastSnapshot("mode", targetDate); - when(periodsDefinition.getRootProjectPastSnapshots()).thenReturn(newArrayList(projectPastSnapshot)); - //when(pastSnapshotFinderByDate.findByDate(anyInt(), any(Date.class))).thenReturn(modulePastSnapshot); - TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(null, (Project) new Project("my:project").setId(projectId), periodsDefinition); + TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(getSession(), (Project) new Project("my:project").setId(1), periodsDefinition); assertThat(timeMachineConfiguration.getProjectPastSnapshots()).hasSize(1); + assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getProjectSnapshot().getId()).isEqualTo(1010); assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getIndex()).isEqualTo(1); assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getMode()).isEqualTo("mode"); assertThat(timeMachineConfiguration.getProjectPastSnapshots().get(0).getModeParameter()).isEqualTo("modeParam"); } @Test - @Ignore - public void get_no_module_past_snapshot() { - Integer projectId = 1; - Date targetDate = new Date(); + public void get_no_date_on_new_project() { + Snapshot projectSnapshot = new Snapshot(); + projectSnapshot.setId(1010); - PastSnapshot projectPastSnapshot = new PastSnapshot("mode", targetDate); + PastSnapshot projectPastSnapshot = new PastSnapshot("mode", new Date(), projectSnapshot); when(periodsDefinition.getRootProjectPastSnapshots()).thenReturn(newArrayList(projectPastSnapshot)); - //when(pastSnapshotFinderByDate.findByDate(eq(projectId), eq(targetDate))).thenReturn(null); - TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(null, (Project) new Project("my:project").setId(projectId), periodsDefinition); - assertThat(timeMachineConfiguration.periods()).isEmpty(); + TimeMachineConfiguration timeMachineConfiguration = new TimeMachineConfiguration(getSession(), new Project("my:project"), periodsDefinition); + assertThat(timeMachineConfiguration.periods()).hasSize(1); + assertThat(timeMachineConfiguration.periods().get(0).getDate()).isNull(); } } diff --git a/sonar-batch/src/test/resources/org/sonar/batch/components/TimeMachineConfigurationTest/shared.xml b/sonar-batch/src/test/resources/org/sonar/batch/components/TimeMachineConfigurationTest/shared.xml index c8796e2bb80..2d267fb2963 100644 --- a/sonar-batch/src/test/resources/org/sonar/batch/components/TimeMachineConfigurationTest/shared.xml +++ b/sonar-batch/src/test/resources/org/sonar/batch/components/TimeMachineConfigurationTest/shared.xml @@ -1,12 +1,15 @@ <dataset> - <projects long_name="[null]" id="1" scope="PRJ" kee="my:project" qualifier="LIB" name="my project as lib" - root_id="[null]" description="[null]" enabled="true" language="java" copy_resource_id="[null]" person_id="[null]"/> - - <projects long_name="[null]" id="2" scope="PRJ" kee="my:project" qualifier="TRK" name="my project" - root_id="[null]" description="[null]" enabled="true" language="java" copy_resource_id="[null]" person_id="[null]"/> - - <projects long_name="[null]" id="3" scope="DIR" kee="my:project:path/to/dir" qualifier="TRK" name="my dir" - root_id="2" description="[null]" enabled="true" language="java" copy_resource_id="[null]" person_id="[null]"/> + <!-- Project --> + <snapshots id="1010" purge_status="[null]" period1_mode="[null]" period1_param="[null]" period1_date="[null]" period2_mode="[null]" period2_param="[null]" period2_date="[null]" period3_mode="[null]" period3_param="[null]" period3_date="[null]" period4_mode="[null]" period4_param="[null]" period4_date="[null]" period5_mode="[null]" period5_param="[null]" period5_date="[null]" + project_id="1" parent_snapshot_id="[null]" root_project_id="[null]" root_snapshot_id="[null]" + scope="PRJ" qualifier="TRK" created_at="2008-11-27 13:58:00.00" build_date="2008-11-27 13:58:00.00" version="1.2-SNAPSHOT" path="" + status="U" islast="false" depth="0" /> + + <!-- Module --> + <snapshots id="1011" purge_status="[null]" period1_mode="[null]" period1_param="[null]" period1_date="[null]" period2_mode="[null]" period2_param="[null]" period2_date="[null]" period3_mode="[null]" period3_param="[null]" period3_date="[null]" period4_mode="[null]" period4_param="[null]" period4_date="[null]" period5_mode="[null]" period5_param="[null]" period5_date="[null]" + project_id="2" parent_snapshot_id="1010" root_project_id="1" root_snapshot_id="1010" + scope="PRJ" qualifier="BRC" created_at="2008-11-27 13:58:00.00" build_date="2008-11-27 13:58:00.00" version="1.2-SNAPSHOT" path="" + status="U" islast="false" depth="0" /> </dataset> |