Skip to content

Commit

Permalink
Better Performance. Added option to avoid updating of snapshot addons
Browse files Browse the repository at this point in the history
  • Loading branch information
gastaldi committed Jul 11, 2013
1 parent 3f6b216 commit 9a2f4e2
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -60,12 +60,27 @@ public class AddonManagerImpl implements AddonManager
{
private final Furnace furnace;
private final AddonDependencyResolver resolver;
private final boolean updateSnapshotDependencies;

@Inject
public AddonManagerImpl(final Furnace forge, final AddonDependencyResolver resolver)
{
this.furnace = forge;
this.resolver = resolver;
this.updateSnapshotDependencies = true;
}

/**
* Used by Arquillian
*
* @param updateDependencies if forge should care about updating SNAPSHOT dependencies
*/
public AddonManagerImpl(final Furnace forge, final AddonDependencyResolver resolver,
boolean updateSnapshotDependencies)
{
this.furnace = forge;
this.resolver = resolver;
this.updateSnapshotDependencies = updateSnapshotDependencies;
}

@Override
Expand Down Expand Up @@ -203,8 +218,7 @@ private AddonActionRequest createRequest(final AddonInfo addonInfo, final Mutabl
if (installedAddons.contains(addon))
{
// Already contains the installed addon. Update ONLY if the version is SNAPSHOT
// TODO: Another asserts may be made at this point, like using timestamps
if (Versions.isSnapshot(addonInfo.getAddon().getVersion()))
if (Versions.isSnapshot(addonInfo.getAddon().getVersion()) && updateSnapshotDependencies)
{
request = createUpdateRequest(addonInfo, addonInfo, repository, furnace);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,7 @@ public ProtocolMetaData deploy(Archive<?> archive) throws DeploymentException
else if (archive instanceof ForgeRemoteAddon)
{
ForgeRemoteAddon remoteAddon = (ForgeRemoteAddon) archive;
AddonManager addonManager = new AddonManagerImpl(runnable.furnace, new MavenDependencyResolver());
AddonManager addonManager = new AddonManagerImpl(runnable.furnace, new MavenDependencyResolver(), false);

addonManager.install(remoteAddon.getAddonId()).perform();

Expand Down

0 comments on commit 9a2f4e2

Please sign in to comment.