]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-4563 Use strict comparison for createdAfter in the Issues search engine
authorSimon Brandhof <simon.brandhof@gmail.com>
Mon, 12 Aug 2013 10:27:03 +0000 (12:27 +0200)
committerSimon Brandhof <simon.brandhof@gmail.com>
Mon, 12 Aug 2013 10:27:03 +0000 (12:27 +0200)
plugins/sonar-core-plugin/src/main/java/org/sonar/plugins/core/issue/notification/NewIssuesEmailTemplate.java
plugins/sonar-core-plugin/src/test/java/org/sonar/plugins/core/issue/notification/NewIssuesEmailTemplateTest.java
sonar-core/src/main/resources/org/sonar/core/issue/db/IssueMapper.xml
sonar-core/src/test/java/org/sonar/core/issue/db/IssueDaoTest.java
sonar-core/src/test/resources/org/sonar/core/issue/db/IssueDaoTest/should_select_by_date_creation.xml
sonar-plugin-api/src/main/java/org/sonar/api/issue/IssueQuery.java
sonar-plugin-api/src/main/java/org/sonar/api/issue/RubyIssueService.java
sonar-server/src/main/java/org/sonar/server/issue/IssueFilterParameters.java
sonar-server/src/main/java/org/sonar/server/issue/PublicRubyIssueService.java

index d479c508d1fef3cbac4b62be76f18349458fbcfb..fd3fc36711f2ecd5a263940f7677a259522f518d 100644 (file)
@@ -68,7 +68,7 @@ public class NewIssuesEmailTemplate extends EmailTemplate {
     String dateString = notification.getFieldValue("projectDate");
     if (projectKey != null && dateString != null) {
       Date date = DateUtils.parseDateTime(dateString);
-      String url = String.format("%s/issues/search?componentRoots=%s&createdAfter=%s",
+      String url = String.format("%s/issues/search?componentRoots=%s&createdAtOrAfter=%s",
         settings.getServerBaseURL(), encode(projectKey), encode(DateUtils.formatDateTime(date)));
       sb.append("\n").append("See it in SonarQube: ").append(url).append("\n");
     }
index eb09ae9c7d9d0c2db1f0ca46618d21c716049e90..97f57cdf8d52b4d9973c44fc645084dac5ec03bf 100644 (file)
@@ -73,7 +73,7 @@ public class NewIssuesEmailTemplateTest {
       "Project: Struts\n" +
       "32 new issues\n" +
       "\n" +
-      "See it in SonarQube: http://nemo.sonarsource.org/issues/search?componentRoots=org.apache%3Astruts&createdAfter=2010-05-18T16%3A50%3A45%2B0200\n");
+      "See it in SonarQube: http://nemo.sonarsource.org/issues/search?componentRoots=org.apache%3Astruts&createdAtOrAfter=2010-05-18T16%3A50%3A45%2B0200\n");
   }
 
   @Test
index 8e65de6406d9b280cee8e743759bbcf58cb100ff..e2c55b4aa9295f3cd004960624830d96696ba12c 100644 (file)
       <if test="query.createdAfter() != null">
         and i.issue_creation_date &gt; #{query.createdAfter}
       </if>
+      <if test="query.createdAtOrAfter() != null">
+        and i.issue_creation_date &gt;= #{query.createdAtOrAfter}
+      </if>
       <if test="query.createdBefore() != null">
         and i.issue_creation_date &lt; #{query.createdBefore}
       </if>
index 69ac592d896742a4d920944e9bad386d0ef4164d..b8fdb2977bc44202235d81f1a9f92a281ab0694d 100644 (file)
@@ -120,8 +120,13 @@ public class IssueDaoTest extends AbstractDaoTestCase {
   public void should_select_by_date_creation() {
     setupData("shared", "should_select_by_date_creation");
 
-    IssueQuery query = IssueQuery.builder().createdAfter(DateUtils.parseDate("2013-04-15")).requiredRole("user").build();
+    IssueQuery query = IssueQuery.builder().createdAfter(DateUtils.parseDate("2013-04-15")).build();
     assertThat(dao.selectIssueIds(query)).hasSize(1);
+    assertThat(dao.selectIssueIds(query).get(0).getId()).isEqualTo(100L);
+
+    query = IssueQuery.builder().createdAtOrAfter(DateUtils.parseDate("2013-04-15")).build();
+    assertThat(dao.selectIssueIds(query)).hasSize(1);
+    assertThat(dao.selectIssueIds(query).get(0).getId()).isEqualTo(100L);
 
     query = IssueQuery.builder().createdBefore(DateUtils.parseDate("2013-04-17")).requiredRole("user").build();
     assertThat(dao.selectIssueIds(query)).hasSize(2);
index cd509c70d50673a77570b527b8242244130d7ee4..cf6048a5e833c44da545954c2d4ef6fe11d6cf09 100644 (file)
@@ -18,7 +18,7 @@
       assignee="perceval"
       author_login="[null]"
       issue_attributes="JIRA=FOO-1234"
-      issue_creation_date="2013-04-16"
+      issue_creation_date="2013-04-16 15:50:45"
       issue_update_date="2013-04-16"
       issue_close_date="2013-04-16"
       created_at="2013-04-16"
index 23e21d30ab660515af9f5b15652ced9da70b4f18..d7ce899c4f8c2d6b659775e9891c61672874771f 100644 (file)
@@ -70,6 +70,7 @@ public class IssueQuery {
   private final Boolean assigned;
   private final Boolean planned;
   private final Boolean resolved;
+  private final Date createdAtOrAfter;
   private final Date createdAfter;
   private final Date createdBefore;
   private final String sort;
@@ -96,6 +97,7 @@ public class IssueQuery {
     this.assigned = builder.assigned;
     this.planned = builder.planned;
     this.resolved = builder.resolved;
+    this.createdAtOrAfter = builder.createdAtOrAfter;
     this.createdAfter = builder.createdAfter;
     this.createdBefore = builder.createdBefore;
     this.sort = builder.sort;
@@ -165,6 +167,11 @@ public class IssueQuery {
     return (createdAfter == null ? null : new Date(createdAfter.getTime()));
   }
 
+  @CheckForNull
+  public Date createdAtOrAfter() {
+    return (createdAtOrAfter == null ? null : new Date(createdAtOrAfter.getTime()));
+  }
+
   @CheckForNull
   public Date createdBefore() {
     return (createdBefore == null ? null : new Date(createdBefore.getTime()));
@@ -219,6 +226,7 @@ public class IssueQuery {
     private Boolean assigned = null;
     private Boolean planned = null;
     private Boolean resolved = null;
+    private Date createdAtOrAfter;
     private Date createdAfter;
     private Date createdBefore;
     private String sort;
@@ -307,6 +315,11 @@ public class IssueQuery {
       return this;
     }
 
+    public Builder createdAtOrAfter(@Nullable Date d) {
+      this.createdAtOrAfter = (d == null ? null : new Date(d.getTime()));
+      return this;
+    }
+
     public Builder createdAfter(@Nullable Date d) {
       this.createdAfter = (d == null ? null : new Date(d.getTime()));
       return this;
index 440105e57870e17ad46ffd1072b2767ec42509c4..1afd5e480ee5a26578f82d57e985c9abf851de7e 100644 (file)
@@ -63,7 +63,9 @@ public interface RubyIssueService extends ServerComponent {
    *   <li>'reporters': list of reporter logins. Note that reporters are defined only on "manual" issues.</li>
    *   <li>'assignees': list of assignee logins.</li>
    *   <li>'assigned': true to get only assigned issues, false to get only unassigned issues. By default no filtering is done.</li>
-   *   <li>'createdAfter': match all the issues created after the given date (inclusive).
+   *   <li>'createdAfter': match all the issues created after the given date (strictly).
+   *   Both date and datetime ISO formats are supported: 2013-05-18 or 2010-05-18T15:50:45+0100</li>
+   *   <li>'createdAtOrAfter': match all the issues created after the given date (inclusive).
    *   Both date and datetime ISO formats are supported: 2013-05-18 or 2010-05-18T15:50:45+0100</li>
    *   <li>'createdBefore': match all the issues created before the given date (exclusive).
    *   Both date and datetime ISO formats are supported: 2013-05-18 or 2010-05-18T15:50:45+0100</li>
index c4b6d9c92db35370fcc8e31cdb08079979d75cb0..d1101062bf5923189c3f1549a26f5549b5d89a9d 100644 (file)
@@ -47,6 +47,7 @@ public class IssueFilterParameters {
   public static final String ASSIGNED = "assigned";
   public static final String PLANNED = "planned";
   public static final String CREATED_AFTER = "createdAfter";
+  public static final String CREATED_AT_OR_AFTER = "createdAtOrAfter";
   public static final String CREATED_BEFORE = "createdBefore";
   public static final String PAGE_SIZE = "pageSize";
   public static final String PAGE_INDEX = "pageIndex";
index b7e7f61661272ae3cfd607029aca14559832bcce..9f39ad2c2fe0587628f7914fa4dd7e4a0046bab0 100644 (file)
@@ -88,6 +88,7 @@ public class PublicRubyIssueService implements RubyIssueService {
       .assignees(RubyUtils.toStrings(props.get(IssueFilterParameters.ASSIGNEES)))
       .assigned(RubyUtils.toBoolean(props.get(IssueFilterParameters.ASSIGNED)))
       .planned(RubyUtils.toBoolean(props.get(IssueFilterParameters.PLANNED)))
+      .createdAtOrAfter(RubyUtils.toDate(props.get(IssueFilterParameters.CREATED_AT_OR_AFTER)))
       .createdAfter(RubyUtils.toDate(props.get(IssueFilterParameters.CREATED_AFTER)))
       .createdBefore(RubyUtils.toDate(props.get(IssueFilterParameters.CREATED_BEFORE)))
       .pageSize(RubyUtils.toInteger(props.get(IssueFilterParameters.PAGE_SIZE)))