aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-server/src/main
diff options
context:
space:
mode:
authorFabrice Bellingard <bellingard@gmail.com>2011-08-26 16:21:38 +0200
committerFabrice Bellingard <bellingard@gmail.com>2011-08-26 16:21:38 +0200
commit1a60b0efffc6f369fdb1796cf6abc5035c558b18 (patch)
treed6e97304f22a917927ff9cd33bf1015f85d91074 /sonar-server/src/main
parent97a58214d83c500121ff2e9e5ddd98730e4e48fd (diff)
downloadsonarqube-1a60b0efffc6f369fdb1796cf6abc5035c558b18.tar.gz
sonarqube-1a60b0efffc6f369fdb1796cf6abc5035c558b18.zip
SONAR-2701 Improve "Time Machine" widget
- Rename numberOfVersions into numberOfColumns - Always take the last snapshot to display
Diffstat (limited to 'sonar-server/src/main')
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/models/snapshot.rb40
1 files changed, 17 insertions, 23 deletions
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/models/snapshot.rb b/sonar-server/src/main/webapp/WEB-INF/app/models/snapshot.rb
index c50e5e54f40..ab8a024f9c3 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/models/snapshot.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/models/snapshot.rb
@@ -68,36 +68,30 @@ class Snapshot < ActiveRecord::Base
snapshots.compact.uniq
end
- def self.for_timemachine_widget(resource, number_of_versions, options={})
+ def self.for_timemachine_widget(resource, number_of_columns, options={})
+ if number_of_columns == 1
+ # Display only the latest snapshot
+ return [resource.last_snapshot]
+ end
+
+ # Get 1rst & latests snapshots of the period
snapshot_conditions = ["snapshots.project_id=? AND snapshots.status=? AND snapshots.scope=? AND snapshots.qualifier=?", resource.id, STATUS_PROCESSED, resource.scope, resource.qualifier]
- event_conditions = ["events.category=? AND events.resource_id=?", "Version", resource.id]
- if (options[:from])
+ if options[:from]
snapshot_conditions[0] += " AND snapshots.created_at>=?"
snapshot_conditions << options[:from]
- event_conditions[0] += " AND events.event_date>=?"
- event_conditions << options[:from]
end
-
- if number_of_versions == 1
- # Display only the latest snapshot
- last_snapshot = Snapshot.find(:last, :conditions => snapshot_conditions, :order => 'snapshots.created_at ASC')
- return [last_snapshot]
- end
-
- # Look for 1rst snapshot of the period
first_snapshot=Snapshot.find(:first, :conditions => snapshot_conditions, :order => 'snapshots.created_at ASC')
+ last_snapshot=resource.last_snapshot
- # Look for the number_of_versions-1 last events to display
- events_to_display = Event.find(:all, :conditions => event_conditions, :order => 'events.event_date ASC').last(number_of_versions-1)
-
- # And retrieve the wanted snapshots corresponding to the events
- sids = []
- events_to_display.each() do |event|
- sids << event.snapshot_id unless event.snapshot_id == first_snapshot.id
- end
- last_snapshots=Snapshot.find(:all, :conditions => ["snapshots.id IN (?)", sids], :include => 'events', :order => 'snapshots.created_at ASC')
+ # Look for the number_of_columns-2 last snapshots to display (they must have 'Version' events)
+ version_snapshots = []
+ if number_of_columns > 2
+ snapshot_conditions[0] += " AND events.snapshot_id=snapshots.id AND events.category='Version' AND snapshots.id NOT IN (?)"
+ snapshot_conditions << [first_snapshot.id, last_snapshot.id]
+ version_snapshots=Snapshot.find(:all, :conditions => snapshot_conditions, :include => 'events', :order => 'snapshots.created_at ASC').last(number_of_columns-2)
+ end
- return [first_snapshot] + last_snapshots
+ return [first_snapshot] + version_snapshots + [last_snapshot]
end
def last?