aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-server
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-server')
-rw-r--r--sonar-server/src/main/java/org/sonar/server/platform/Platform.java2
-rw-r--r--sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterClient.java13
-rw-r--r--sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrix.java (renamed from sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinder.java)41
-rw-r--r--sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrixFactory.java (renamed from sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinderFactory.java)21
-rw-r--r--sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java18
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/controllers/updatecenter_controller.rb23
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/helpers/updatecenter_helper.rb2
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb4
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_list.html.erb45
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_operations.html.erb11
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_status.html.erb14
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/available.html.erb40
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/index.html.erb2
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/updates.html.erb180
-rw-r--r--sonar-server/src/test/java/org/sonar/server/plugins/UpdateCenterMatrixTest.java (renamed from sonar-server/src/test/java/org/sonar/server/plugins/UpdateFinderTest.java)54
15 files changed, 252 insertions, 218 deletions
diff --git a/sonar-server/src/main/java/org/sonar/server/platform/Platform.java b/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
index a268efc3766..9cec2e85564 100644
--- a/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
+++ b/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
@@ -135,7 +135,7 @@ public final class Platform {
coreContainer.as(Characteristics.CACHE).addComponent(ThreadLocalDatabaseSessionFactory.class);
coreContainer.as(Characteristics.CACHE).addComponent(HttpDownloader.class);
coreContainer.as(Characteristics.CACHE).addComponent(UpdateCenterClient.class);
- coreContainer.as(Characteristics.CACHE).addComponent(UpdateFinderFactory.class);
+ coreContainer.as(Characteristics.CACHE).addComponent(UpdateCenterMatrixFactory.class);
coreContainer.as(Characteristics.CACHE).addComponent(PluginDownloader.class);
coreContainer.as(Characteristics.NO_CACHE).addComponent(FilterExecutor.class);
coreContainer.as(Characteristics.NO_CACHE).addAdapter(new DatabaseSessionProvider());
diff --git a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterClient.java b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterClient.java
index 575ba0799c7..f46baa4f42c 100644
--- a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterClient.java
+++ b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterClient.java
@@ -30,11 +30,12 @@ import org.sonar.updatecenter.common.UpdateCenterDeserializer;
import java.io.InputStream;
import java.net.URI;
+import java.util.Date;
import java.util.Properties;
/**
* HTTP client to load data from the remote update center hosted at http://update.sonarsource.org.
- * @since 2.2
+ * @since 2.4
*/
public class UpdateCenterClient implements ServerComponent {
@@ -44,7 +45,7 @@ public class UpdateCenterClient implements ServerComponent {
private String url;
private UpdateCenter center = null;
- private long downloadDate = 0;
+ private long lastRefreshDate = 0;
private HttpDownloader downloader;
/**
@@ -67,13 +68,17 @@ public class UpdateCenterClient implements ServerComponent {
public UpdateCenter getCenter(boolean forceRefresh) {
if (center == null || forceRefresh || needsRefresh()) {
center = download();
- downloadDate = System.currentTimeMillis();
+ lastRefreshDate = System.currentTimeMillis();
}
return center;
}
+ public Date getLastRefreshDate() {
+ return lastRefreshDate >0 ? new Date(lastRefreshDate) : null;
+ }
+
private boolean needsRefresh() {
- return downloadDate + PERIOD_IN_MILLISECONDS < System.currentTimeMillis();
+ return lastRefreshDate + PERIOD_IN_MILLISECONDS < System.currentTimeMillis();
}
private UpdateCenter download() {
diff --git a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinder.java b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrix.java
index c18c94b5a32..a5c698539c3 100644
--- a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinder.java
+++ b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrix.java
@@ -19,23 +19,29 @@
*/
package org.sonar.server.plugins;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
import org.sonar.updatecenter.common.*;
-import java.util.*;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+import java.util.SortedSet;
-public final class UpdateFinder {
+public final class UpdateCenterMatrix {
private UpdateCenter center;
private Version installedSonarVersion;
- private Map<Plugin, Version> installedPlugins = new HashMap<Plugin, Version>();
- private List<String> pendingPluginFilenames = new ArrayList<String>();
+ private Map<Plugin, Version> installedPlugins = Maps.newHashMap();
+ private List<String> pendingPluginFilenames = Lists.newArrayList();
+ private Date date;
- public UpdateFinder(UpdateCenter center, Version installedSonarVersion) {
+ public UpdateCenterMatrix(UpdateCenter center, Version installedSonarVersion) {
this.center = center;
this.installedSonarVersion = installedSonarVersion;
}
- public UpdateFinder(UpdateCenter center, String installedSonarVersion) {
+ public UpdateCenterMatrix(UpdateCenter center, String installedSonarVersion) {
this(center, Version.create(installedSonarVersion));
}
@@ -47,7 +53,7 @@ public final class UpdateFinder {
return installedSonarVersion;
}
- public UpdateFinder registerInstalledPlugin(String pluginKey, Version pluginVersion) {
+ public UpdateCenterMatrix registerInstalledPlugin(String pluginKey, Version pluginVersion) {
Plugin plugin = center.getPlugin(pluginKey);
if (plugin != null) {
installedPlugins.put(plugin, pluginVersion);
@@ -55,15 +61,15 @@ public final class UpdateFinder {
return this;
}
- public UpdateFinder registerPendingPluginsByFilename(String filename) {
+ public UpdateCenterMatrix registerPendingPluginsByFilename(String filename) {
pendingPluginFilenames.add(filename);
return this;
}
public List<PluginUpdate> findAvailablePlugins() {
- List<PluginUpdate> availables = new ArrayList<PluginUpdate>();
+ List<PluginUpdate> availables = Lists.newArrayList();
for (Plugin plugin : center.getPlugins()) {
- if ( !installedPlugins.containsKey(plugin) && !isAlreadyDownloaded(plugin)) {
+ if (!installedPlugins.containsKey(plugin) && !isAlreadyDownloaded(plugin)) {
Release release = plugin.getLastCompatibleRelease(installedSonarVersion);
if (release != null) {
availables.add(PluginUpdate.createWithStatus(release, PluginUpdate.Status.COMPATIBLE));
@@ -90,10 +96,10 @@ public final class UpdateFinder {
}
public List<PluginUpdate> findPluginUpdates() {
- List<PluginUpdate> updates = new ArrayList<PluginUpdate>();
+ List<PluginUpdate> updates = Lists.newArrayList();
for (Map.Entry<Plugin, Version> entry : installedPlugins.entrySet()) {
Plugin plugin = entry.getKey();
- if ( !isAlreadyDownloaded(plugin)) {
+ if (!isAlreadyDownloaded(plugin)) {
Version pluginVersion = entry.getValue();
for (Release release : plugin.getReleasesGreaterThan(pluginVersion)) {
updates.add(PluginUpdate.createForPluginRelease(release, installedSonarVersion));
@@ -104,7 +110,7 @@ public final class UpdateFinder {
}
public List<SonarUpdate> findSonarUpdates() {
- List<SonarUpdate> updates = new ArrayList<SonarUpdate>();
+ List<SonarUpdate> updates = Lists.newArrayList();
SortedSet<Release> releases = center.getSonar().getReleasesGreaterThan(installedSonarVersion);
for (Release release : releases) {
updates.add(createSonarUpdate(release));
@@ -144,4 +150,13 @@ public final class UpdateFinder {
}
return update;
}
+
+ public Date getDate() {
+ return date;
+ }
+
+ public UpdateCenterMatrix setDate(Date d) {
+ this.date = d;
+ return this;
+ }
}
diff --git a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinderFactory.java b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrixFactory.java
index 0963112fb25..6e33ace2d42 100644
--- a/sonar-server/src/main/java/org/sonar/server/plugins/UpdateFinderFactory.java
+++ b/sonar-server/src/main/java/org/sonar/server/plugins/UpdateCenterMatrixFactory.java
@@ -26,33 +26,38 @@ import org.sonar.api.platform.Server;
import org.sonar.updatecenter.common.UpdateCenter;
import org.sonar.updatecenter.common.Version;
-public final class UpdateFinderFactory implements ServerComponent {
+/**
+ * @since 2.4
+ */
+public final class UpdateCenterMatrixFactory implements ServerComponent {
private UpdateCenterClient centerClient;
private JpaPluginDao dao;
private Version sonarVersion;
private PluginDownloader downloader;
- public UpdateFinderFactory(UpdateCenterClient centerClient, JpaPluginDao dao, Server server, PluginDownloader downloader) {
+ public UpdateCenterMatrixFactory(UpdateCenterClient centerClient, JpaPluginDao dao, Server server, PluginDownloader downloader) {
this.centerClient = centerClient;
this.dao = dao;
this.sonarVersion = Version.create(server.getVersion());
this.downloader = downloader;
}
- public UpdateFinder getFinder(boolean refresh) {
+ public UpdateCenterMatrix getMatrix(boolean refresh) {
UpdateCenter center = centerClient.getCenter(refresh);
- UpdateFinder finder = null;
+ UpdateCenterMatrix matrix = null;
if (center != null) {
- finder = new UpdateFinder(center, sonarVersion);
+ matrix = new UpdateCenterMatrix(center, sonarVersion);
+ matrix.setDate(centerClient.getLastRefreshDate());
+
for (JpaPlugin plugin : dao.getPlugins()) {
- finder.registerInstalledPlugin(plugin.getKey(), Version.create(plugin.getVersion()));
+ matrix.registerInstalledPlugin(plugin.getKey(), Version.create(plugin.getVersion()));
}
for (String filename : downloader.getDownloads()) {
- finder.registerPendingPluginsByFilename(filename);
+ matrix.registerPendingPluginsByFilename(filename);
}
}
- return finder;
+ return matrix;
}
}
diff --git a/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java b/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
index f5dc477cd43..883f5e34b63 100644
--- a/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
+++ b/sonar-server/src/main/java/org/sonar/server/ui/JRubyFacade.java
@@ -47,11 +47,8 @@ import org.sonar.server.filters.Filter;
import org.sonar.server.filters.FilterExecutor;
import org.sonar.server.filters.FilterResult;
import org.sonar.server.platform.Platform;
-import org.sonar.server.plugins.PluginClassLoaders;
-import org.sonar.server.plugins.PluginDeployer;
-import org.sonar.server.plugins.PluginDownloader;
-import org.sonar.server.plugins.UpdateFinder;
-import org.sonar.server.plugins.UpdateFinderFactory;
+import org.sonar.server.plugins.*;
+import org.sonar.server.plugins.UpdateCenterMatrix;
import org.sonar.server.rules.ProfilesConsole;
import org.sonar.server.rules.RulesConsole;
import org.sonar.updatecenter.common.Version;
@@ -65,7 +62,8 @@ public final class JRubyFacade implements ServerComponent {
return getContainer().getComponent(FilterExecutor.class).execute(filter);
}
- /* PLUGINS */
+ /* UPDATE CENTER */
+
public void downloadPlugin(String pluginKey, String pluginVersion) {
getContainer().getComponent(PluginDownloader.class).download(pluginKey, Version.create(pluginVersion));
}
@@ -90,10 +88,14 @@ public final class JRubyFacade implements ServerComponent {
return getContainer().getComponent(PluginDeployer.class).getUninstalls();
}
- public UpdateFinder getUpdateFinder(boolean forceReload) {
- return getContainer().getComponent(UpdateFinderFactory.class).getFinder(forceReload);
+ public UpdateCenterMatrix getUpdateCenterMatrix(boolean forceReload) {
+ return getContainer().getComponent(UpdateCenterMatrixFactory.class).getMatrix(forceReload);
}
+
+
+
+
public String colorizeCode(String code, String language) {
try {
return getContainer().getComponent(CodeColorizers.class).toHtml(code, language);
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/controllers/updatecenter_controller.rb b/sonar-server/src/main/webapp/WEB-INF/app/controllers/updatecenter_controller.rb
index 6a84b0fa634..429602cc5fb 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/controllers/updatecenter_controller.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/controllers/updatecenter_controller.rb
@@ -38,6 +38,7 @@ class UpdatecenterController < ApplicationController
@downloads=java_facade.getPluginDownloads()
@center=nil
+ @matrix=nil
@sonar_updates=[]
@updates_by_plugin={}
@user_plugins={}
@@ -47,12 +48,12 @@ class UpdatecenterController < ApplicationController
@user_plugins[plugin.plugin_key]=plugin.version
end
- finder=load_update_finder()
- if finder
- @center=finder.getCenter()
- @sonar_updates=finder.findSonarUpdates()
+ load_matrix()
+ if @matrix
+ @center=@matrix.getCenter()
+ @sonar_updates=@matrix.findSonarUpdates()
- @finder.findPluginUpdates().each do |update|
+ @matrix.findPluginUpdates().each do |update|
plugin=update.getPlugin()
@updates_by_plugin[plugin]||=[]
@updates_by_plugin[plugin]<<update
@@ -70,10 +71,10 @@ class UpdatecenterController < ApplicationController
@center=nil
@updates_by_category={}
- finder=load_update_finder()
- if finder
- @center=finder.getCenter()
- finder.findAvailablePlugins().each do |update|
+ load_matrix()
+ if @matrix
+ @center=@matrix.getCenter()
+ @matrix.findAvailablePlugins().each do |update|
category=update.getPlugin().getCategory()||''
@updates_by_category[category]||=[]
@updates_by_category[category]<<update
@@ -119,8 +120,8 @@ class UpdatecenterController < ApplicationController
end
private
- def load_update_finder
- @finder=java_facade.getUpdateFinder(params[:reload]=='true')
+ def load_matrix
+ @matrix=java_facade.getUpdateCenterMatrix(params[:reload]=='true')
end
def updatecenter_activated
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/helpers/updatecenter_helper.rb b/sonar-server/src/main/webapp/WEB-INF/app/helpers/updatecenter_helper.rb
index 30e23f9c8e9..04139237bee 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/helpers/updatecenter_helper.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/helpers/updatecenter_helper.rb
@@ -20,7 +20,7 @@
module UpdatecenterHelper
def release_date(date)
- Time.at(date.getTime() / 1000).strftime('%B %e, %Y')
+ Time.at(date.getTime() / 1000).strftime('%b %e, %Y')
end
end
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
index e223270877a..cedafc0abcb 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
@@ -75,10 +75,10 @@
<li class="h2">System</li>
<li class="<%= 'selected' if request.request_uri.include?('/settings') -%>"><a href="<%= ApplicationController.root_context -%>/settings/index">Settings</a></li>
<li class="<%= 'selected' if controller.controller_path=='backup' -%>"><a href="<%= ApplicationController.root_context -%>/backup">Backup</a></li>
- <li class="<%= 'selected' if controller.controller_path=='system' -%>"><a href="<%= ApplicationController.root_context -%>/system">System info</a></li>
+ <li class="<%= 'selected' if controller.controller_path=='system' -%>"><a href="<%= ApplicationController.root_context -%>/system">System Info</a></li>
<% update_center_activated = controller.java_facade.getConfigurationValue('sonar.updatecenter.activate') || 'true';
if update_center_activated=='true' %>
- <li class="<%= 'selected' if controller.controller_path=='updatecenter' -%>"><a href="<%= ApplicationController.root_context -%>/updatecenter">Upgrades (BETA)</a></li>
+ <li class="<%= 'selected' if controller.controller_path=='updatecenter' -%>"><a href="<%= ApplicationController.root_context -%>/updatecenter">Update Center</a></li>
<% end %>
<% end %>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_list.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_list.html.erb
index ec8a5b7efa2..e69de29bb2d 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_list.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_list.html.erb
@@ -1,45 +0,0 @@
-<% updates.each do |update|
- release=update.getRelease()
-%>
- <tr class="<%= cycle('even','odd', :name => 'system') if !plugin -%>">
- <td width="1%" nowrap><b><%= 'Sonar' if !plugin -%> <%= release.getVersion() -%></b></td>
- <td width="1%" nowrap><%= release_date(release.getDate()) if release.getDate() -%></td>
- <td><%= release.getDescription() -%></td>
- <td>
- <%= link_to 'Release Notes', release.getChangelogUrl(), :class => 'external' if release.getChangelogUrl() %> &nbsp;
- <%= link_to 'Download', release.getDownloadUrl(), :class => 'external' if !plugin && release.getDownloadUrl() %>
- </td>
- <% if plugin %>
- <td>
- <% if update.isIncompatible() %>
- not compatible
- <% elsif update.requiresSonarUpgrade %>
- not compatible, needs Sonar upgrade
- <% end %>
- </td>
- <% else %>
- <td>
- <% if update.hasWarnings() %>
- <% if update.isIncompatible() %>
- Those plugins not compatible and must be uninstalled before Sonar upgrade:
- <ul>
- <% update.getIncompatiblePlugins().each do |plugin| %>
- <li><%= plugin.getName() -%></li>
- <% end %>
- </ul>
- <% end %>
- <% if update.requiresPluginUpgrades() %>
- Those plugins must be upgraded:
- <ul>
- <% update.getPluginsToUpgrade().each do |plugin| %>
- <li><%= plugin.getArtifact().getName() -%> to <%= plugin.getVersion() -%></li>
- <% end %>
- </ul>
- <% end %>
- <% else %>
- All installed plugins are compatible
- <% end %>
- </td>
- <% end %>
- </tr>
-<% end %>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_operations.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_operations.html.erb
index 2a72d44f3f7..a46d5e60fa6 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_operations.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_operations.html.erb
@@ -7,15 +7,6 @@
}
return false;
}
-
- function checkTermsConditions(key) {
- var tc=$('tc-' + key)
- if (tc!=null && !tc.checked) {
- alert('Please accept the Terms and Conditions');
- return false;
- }
- return true;
- }
</script>
<% if @uninstalls.size > 0 %>
@@ -37,7 +28,7 @@
<li><%= download -%></li>
<% end %>
</ul>
- <input type="submit" value="Cancel downloads"></input>
+ <input type="submit" value="Cancel pending installations"></input>
</p>
</form>
<% end %>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_status.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_status.html.erb
index a6defc2d88b..00f473ee3a1 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_status.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/_status.html.erb
@@ -1,7 +1,7 @@
-<p class="notes">
- <% if @center.nil? %>
- <p>Not connected to update center. Please check your internet connection and logs.</p>
- <% else %>
- Updated on <%= @center.getDate() %>. <%= link_to 'Refresh', :action => action, :reload => true %>
- <% end %>
-</p>
+<% if @center.nil? %>
+ <p class="error">Not connected to update center. Please check your internet connection and logs.</p>
+<% else %>
+ <p class="notes">
+ Updated on <%= @matrix.getDate() -%>. <%= link_to 'Refresh', :action => action, :reload => true %>
+ </p>
+<% end %> \ No newline at end of file
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/available.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/available.html.erb
index 3b17d550e92..e4ccf1b0b5a 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/available.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/available.html.erb
@@ -1,3 +1,18 @@
+<script>
+function installPlugin(key) {
+ /* check terms & conditions */
+ var tc=$('tc-' + key)
+ if (tc!=null && !tc.checked) {
+ alert('Please accept the Terms and Conditions');
+ return false;
+ }
+ var button=$('submit-' + key);
+ button.disable();
+ button.writeAttribute('value', 'Installing');
+ return true;
+}
+</script>
+
<ul class="tabs">
<li>
<a href="<%= url_for :action => 'index' -%>">Installed</a>
@@ -13,22 +28,22 @@
<%= render :partial => 'updatecenter/operations' -%>
-<table class="data width100">
- <thead>
- </thead>
- <tbody>
<% if @center %>
<% @updates_by_category.keys.sort_by{|c| c.downcase }.each do |category|
updates=@updates_by_category[category]
%>
- <tr>
- <td colspan="2"><h2><%= category -%></h2></td>
- </tr>
+ <table class="data width100">
+ <thead>
+ <tr>
+ <th colspan="2"><h2><%= category -%></h2></th>
+ </tr>
+ </thead>
+ <tbody>
<% updates.sort_by{|c| c.getPlugin().getName()}.each do |update|
plugin=update.getPlugin()
%>
<tr class="<%= cycle('even','odd', :name => category) -%>">
- <td width="1%" nowrap>
+ <td width="150" nowrap>
<b><a href="#plugin" onClick="showPlugin('<%= plugin.getKey() -%>');"><%= h(plugin.getName()) -%></a></b>
</td>
<td>
@@ -64,8 +79,8 @@
<% if plugin.getTermsConditionsUrl() %>
<input type="checkbox" id="tc-<%= plugin.getKey() -%>"></input> I accept the <%= link_to 'Terms and Conditions', plugin.getTermsConditionsUrl(), :class => 'external' %>
<% end %>
- <form method="post" action="<%= ApplicationController.root_context -%>/updatecenter/install?from=available&key=<%= plugin.getKey() -%>&version=<%= update.getRelease().getVersion() -%>" style="display: inline-block">
- <input type="submit" value="Install" onClick="return checkTermsConditions('<%= plugin.getKey() -%>')"></input>
+ <form method="post" action="<%= ApplicationController.root_context -%>/updatecenter/install?from=available&key=<%= plugin.getKey() -%>&version=<%= update.getRelease().getVersion() -%>" style="display: inline-block" id="install-<%= plugin.getKey() -%>">
+ <input type="submit" value="Install" onClick="return installPlugin('<%= plugin.getKey() -%>')" id="submit-<%= plugin.getKey() -%>"></input>
</form>
</div>
<% elsif update.requiresSonarUpgrade
@@ -80,10 +95,11 @@
</td>
</tr>
<% end %>
+ </tbody>
+ </table>
+ <div class="break30"> </div>
<% end %>
<% end %>
-</tbody>
-</table><br/>
<%= render :partial => 'updatecenter/status', :locals => {:action => 'available' } %>
</div>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/index.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/index.html.erb
index 71996d7453f..ff599694e49 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/index.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/index.html.erb
@@ -15,7 +15,7 @@
<table class="data width100" id="user-plugins">
<thead>
- <tr><th colspan="3"><h2>User-installed plugins</h2></th></tr>
+ <tr><th colspan="3"><h2>Plugins</h2></th></tr>
<tr>
<th>Plugin</th>
<th>Version</th>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/updates.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/updates.html.erb
index b9f9d636f51..58f7fca5504 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/updates.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/updatecenter/updates.html.erb
@@ -1,72 +1,116 @@
-<ul class="tabs">
- <li>
- <a href="<%= url_for :action => 'index' -%>">Installed</a>
- </li>
- <li>
- <a href="<%= url_for :action => 'updates' -%>" class="selected">Updates</a>
- </li>
- <li>
- <a href="<%= url_for :action => 'available' -%>">Available</a>
- </li>
-</ul>
-<div class="tabs-panel">
+ <ul class="tabs">
+ <li>
+ <a href="<%= url_for :action => 'index' -%>">Installed</a>
+ </li>
+ <li>
+ <a href="<%= url_for :action => 'updates' -%>" class="selected">Updates</a>
+ </li>
+ <li>
+ <a href="<%= url_for :action => 'available' -%>">Available</a>
+ </li>
+ </ul>
+ <div class="tabs-panel">
-<%= render :partial => 'updatecenter/operations' -%>
+ <%= render :partial => 'updatecenter/operations' -%>
-<% if @center %>
- <table class="data width100" id="plugin-updates">
- <thead>
- <tr><th colspan="2"><h2>User-installed plugins</h2></th></tr>
- </thead>
- <tbody>
- <% if @updates_by_plugin.empty? %>
- <tr class="even">
- <td colspan="2">No updates</td>
- </tr>
- <% end %>
- <% @updates_by_plugin.keys.each do |plugin|
- updates=@updates_by_plugin[plugin]
- %>
- <tr class="<%= cycle('even','odd', :name => 'user-plugins') -%>">
- <td width="1%" nowrap>
- <b><a href="#plugin" onclick="showPlugin('<%= plugin.getKey() -%>')"><%= h(plugin.getName()) -%></a></b>
- </td>
- <td>
- Current version: <b><%= @user_plugins[plugin.getKey()] -%></b>,
- last compatible: <b><%= @last_compatible[plugin.getKey()] -%></b>,
- latest: <b><%= updates.last.getRelease().getVersion() -%></b>
- <div id="detail-<%= plugin.getKey() -%>" style="display:none">
- <table class="spaced">
- <tbody>
- <%= render :partial => 'updatecenter/list', :locals => {:updates => updates, :plugin => true } %>
- </tbody>
- </table>
- <form method="post" action="<%= ApplicationController.root_context -%>/updatecenter/install?from=updates&key=<%= plugin.getKey() -%>&version=<%= @last_compatible[plugin.getKey()] -%>" style="display: inline-block">
- <input type="submit" value="Update to <%= @last_compatible[plugin.getKey()] -%>"></input>
- </form>
- </div>
- </td>
- </tr>
- <% end %>
- </tbody>
- </table>
+ <% if @center %>
+ <table class="data width100" id="plugin-updates">
+ <thead>
+ <tr><th colspan="2"><h2>Plugins</h2></th></tr>
+ </thead>
+ <tbody>
+ <% if @updates_by_plugin.empty? %>
+ <tr class="even">
+ <td colspan="2">No updates</td>
+ </tr>
+ <% end %>
+ <% @updates_by_plugin.keys.each do |plugin|
+ css=cycle('even','odd', :name => 'user-plugins')
+ updates=@updates_by_plugin[plugin]
+ updates.each_with_index do |update, index|
+ release=update.getRelease()
+ %>
+ <tr class="<%= css -%>">
+ <td width="1%" nowrap><% if index==0 %><b><%= h(plugin.getName()) -%></b> <%= @user_plugins[plugin.getKey()] -%> -> <% end %></td>
+ <td width="1%" nowrap><b><%= release.getVersion() -%></b></td>
+ <td width="1%" nowrap><%= release_date(release.getDate()) if release.getDate() -%></td>
+ <td><%= release.getDescription() -%></td>
+ <td><%= link_to 'Release Notes', release.getChangelogUrl(), :class => 'external' if release.getChangelogUrl() %></td>
+ <td>
+ <% if update.isIncompatible() %>
+ <%= image_tag 'warning.png' -%> Not compatible
+ <% elsif update.requiresSonarUpgrade %>
+ <%= image_tag 'warning.png' -%> Not compatible, requires to upgrade system
+ <% end %>
+ </td>
+ </tr>
+ <%
+ end
+ %>
+ <tr class="<%= css -%>">
+ <td> </td>
+ <td colspan="5">
+ <form method="post" action="<%= ApplicationController.root_context -%>/updatecenter/install?from=updates&key=<%= plugin.getKey() -%>&version=<%= @last_compatible[plugin.getKey()] -%>" style="display: inline-block">
+ <input type="submit" value="Upgrade to <%= @last_compatible[plugin.getKey()] -%>"></input>
+ </form>
+ </td>
+ </tr>
+ <%
+ end
+ %>
+ </tbody>
+ </table>
- <div class="break30"> </div>
+ <div class="break30"> </div>
- <table class="data width100" id="system-updates">
- <thead>
- <tr><th colspan="4"><h2>System</h2></th></tr>
- </thead>
- <tbody>
- <% if @sonar_updates.empty? %>
- <tr class="even">
- <td colspan="4" >No updates</td>
- </tr>
- <% end %>
- <%= render :partial => 'updatecenter/list', :locals => {:updates => @sonar_updates, :plugin => false } %>
- </tbody>
- </table>
- <br/>
-<% end %>
-<%= render :partial => 'updatecenter/status', :locals => {:action => 'updates' } %>
-</div>
+ <table class="data width100 marginbottom10" id="system-updates">
+ <thead>
+ <tr><th colspan="4"><h2>System</h2></th></tr>
+ </thead>
+ <tbody>
+ <% if @sonar_updates.empty? %>
+ <tr class="even">
+ <td colspan="4" >No updates</td>
+ </tr>
+ <% end %>
+
+
+
+ <% @sonar_updates.each do |update|
+ css=cycle('even','odd', :name => 'system')
+ release=update.getRelease()
+ %>
+ <tr class="<%= css -%>">
+ <td width="1%" nowrap><b>Sonar <%= release.getVersion() -%></b></td>
+ <td width="1%" nowrap><%= release_date(release.getDate()) if release.getDate() -%></td>
+ <td><%= release.getDescription() -%></td>
+ <td>
+ <%= link_to 'Release Notes', release.getChangelogUrl(), :class => 'external' if release.getChangelogUrl() %> &nbsp;
+ <%= link_to 'Download', release.getDownloadUrl(), :class => 'external' if release.getDownloadUrl() %>
+ </td>
+ </tr>
+ <% if update.hasWarnings() %>
+ <tr class="<%= css -%>">
+ <td> </td>
+ <td colspan="3">
+ <% if update.isIncompatible() %>
+ <%= image_tag 'warning.png' -%> Not compatible plugins must be uninstalled before upgrading system:
+ <%= update.getIncompatiblePlugins().map{|plugin| plugin.getName()}.sort.join(',') -%>
+ <% end %>
+ <% if update.requiresPluginUpgrades() %>
+ <%= image_tag 'warning.png' -%> Following plugins must be upgraded before upgrading system:
+ <ul>
+ <% update.getPluginsToUpgrade().each do |plugin| %>
+ <li><%= plugin.getArtifact().getName() -%> to <%= plugin.getVersion() -%></li>
+ <% end %>
+ </ul>
+ <% end %>
+ </td>
+ </tr>
+ <% end %>
+ <% end %>
+ </tbody>
+ </table>
+ <% end %>
+ <%= render :partial => 'updatecenter/status', :locals => {:action => 'updates' } %>
+ </div>
diff --git a/sonar-server/src/test/java/org/sonar/server/plugins/UpdateFinderTest.java b/sonar-server/src/test/java/org/sonar/server/plugins/UpdateCenterMatrixTest.java
index db453d1b515..b8c162acdc8 100644
--- a/sonar-server/src/test/java/org/sonar/server/plugins/UpdateFinderTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/plugins/UpdateCenterMatrixTest.java
@@ -32,7 +32,7 @@ import static org.hamcrest.Matchers.is;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
-public class UpdateFinderTest {
+public class UpdateCenterMatrixTest {
private UpdateCenter center;
private Plugin foo;
@@ -66,9 +66,9 @@ public class UpdateFinderTest {
@Test
public void findPluginUpdates() {
- UpdateFinder finder = new UpdateFinder(center, "2.1");
- finder.registerInstalledPlugin("foo", Version.create("1.0"));
- List<PluginUpdate> updates = finder.findPluginUpdates();
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.1");
+ matrix.registerInstalledPlugin("foo", Version.create("1.0"));
+ List<PluginUpdate> updates = matrix.findPluginUpdates();
assertThat(updates.size(), is(2));
assertThat(updates.get(0).getRelease(), is(foo11));
@@ -81,17 +81,17 @@ public class UpdateFinderTest {
@Test
public void noPluginUpdatesIfLastReleaseIsInstalled() {
- UpdateFinder finder = new UpdateFinder(center, "2.3");
- finder.registerInstalledPlugin("foo", Version.create("1.2"));
- assertTrue(finder.findPluginUpdates().isEmpty());
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.3");
+ matrix.registerInstalledPlugin("foo", Version.create("1.2"));
+ assertTrue(matrix.findPluginUpdates().isEmpty());
}
@Test
public void availablePluginsAreOnlyTheBestReleases() {
- UpdateFinder finder = new UpdateFinder(center, "2.2");
- finder.registerInstalledPlugin("foo", Version.create("1.0"));
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.2");
+ matrix.registerInstalledPlugin("foo", Version.create("1.0"));
- List<PluginUpdate> availables = finder.findAvailablePlugins();
+ List<PluginUpdate> availables = matrix.findAvailablePlugins();
// bar 1.0 is compatible with the installed sonar
// bar 1.1 requires sonar to be upgraded to 2.2.2 or 2.3
@@ -103,10 +103,10 @@ public class UpdateFinderTest {
@Test
public void availablePluginsRequireSonarUpgrade() {
- UpdateFinder finder = new UpdateFinder(center, "2.2.1");
- finder.registerInstalledPlugin("foo", Version.create("1.0"));
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.2.1");
+ matrix.registerInstalledPlugin("foo", Version.create("1.0"));
- List<PluginUpdate> availables = finder.findAvailablePlugins();
+ List<PluginUpdate> availables = matrix.findAvailablePlugins();
// bar 1.0 is not compatible with the installed sonar
// bar 1.1 requires sonar to be upgraded to 2.2.2 or 2.3
@@ -121,8 +121,8 @@ public class UpdateFinderTest {
center.getSonar().addRelease(Version.create("2.3"));
center.getSonar().addRelease(Version.create("2.4"));
- UpdateFinder finder = new UpdateFinder(center, "2.2");
- List<SonarUpdate> updates = finder.findSonarUpdates();
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.2");
+ List<SonarUpdate> updates = matrix.findSonarUpdates();
// no plugins are installed, so both sonar versions are compatible
assertThat(updates.size(), is(2));
@@ -135,10 +135,10 @@ public class UpdateFinderTest {
center.getSonar().addRelease(Version.create("2.3"));
center.getSonar().addRelease(Version.create("2.4"));
- UpdateFinder finder = new UpdateFinder(center, "2.2");
- finder.registerInstalledPlugin("foo", Version.create("1.0"));
- finder.registerInstalledPlugin("bar", Version.create("1.0"));
- List<SonarUpdate> updates = finder.findSonarUpdates();
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.2");
+ matrix.registerInstalledPlugin("foo", Version.create("1.0"));
+ matrix.registerInstalledPlugin("bar", Version.create("1.0"));
+ List<SonarUpdate> updates = matrix.findSonarUpdates();
assertThat(updates.size(), is(2));
@@ -156,19 +156,19 @@ public class UpdateFinderTest {
@Test
public void excludePendingDownloadsFromPluginUpdates() {
- UpdateFinder finder = new UpdateFinder(center, "2.1");
- finder.registerInstalledPlugin("foo", Version.create("1.0"));
- finder.registerPendingPluginsByFilename("foo-1.0.jar");
- List<PluginUpdate> updates = finder.findPluginUpdates();
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.1");
+ matrix.registerInstalledPlugin("foo", Version.create("1.0"));
+ matrix.registerPendingPluginsByFilename("foo-1.0.jar");
+ List<PluginUpdate> updates = matrix.findPluginUpdates();
assertThat(updates.size(), is(0));
}
@Test
public void excludePendingDownloadsFromAvailablePlugins() {
- UpdateFinder finder = new UpdateFinder(center, "2.1");
- finder.registerPendingPluginsByFilename("foo-1.0.jar");
- finder.registerPendingPluginsByFilename("bar-1.1.jar");
- List<PluginUpdate> updates = finder.findAvailablePlugins();
+ UpdateCenterMatrix matrix = new UpdateCenterMatrix(center, "2.1");
+ matrix.registerPendingPluginsByFilename("foo-1.0.jar");
+ matrix.registerPendingPluginsByFilename("bar-1.1.jar");
+ List<PluginUpdate> updates = matrix.findAvailablePlugins();
assertThat(updates.size(), is(0));
}
}