hudson.scm
Class SubversionSCM

java.lang.Object
  extended by hudson.scm.SCM
      extended by hudson.scm.SubversionSCM
All Implemented Interfaces:
hudson.ExtensionPoint, hudson.model.Describable<hudson.scm.SCM>, Serializable

public class SubversionSCM
extends hudson.scm.SCM
implements Serializable

Subversion SCM.

Plugin Developer Notes

Plugins that interact with Subversion can use SubversionSCM.DescriptorImpl.createAuthenticationProvider(AbstractProject) so that it can use the credentials (username, password, etc.) that the user entered for Hudson. See the javadoc of this method for the precautions you need to take if you run Subversion operations remotely on slaves.

Implementation Notes

Because this instance refers to some other classes that are not necessarily Java serializable (like browser), remotable FilePath.FileCallables all need to be declared as static inner classes.

Author:
Kohsuke Kawaguchi
See Also:
Serialized Form

Nested Class Summary
static class SubversionSCM.DescriptorImpl
           
static class SubversionSCM.External
          Information about svn:external
static class SubversionSCM.ModuleLocation
          small structure to store local and remote (repository) location information of the repository.
static class SubversionSCM.RevisionPolicy
          Supported revision policies.
static class SubversionSCM.SvnInfo
           
 
Nested classes/interfaces inherited from interface hudson.ExtensionPoint
hudson.ExtensionPoint.LegacyInstancesAreScopedToHudson
 
Field Summary
static int DEFAULT_TIMEOUT
          Network timeout in milliseconds.
static boolean POLL_FROM_MASTER
          Property to control whether SCM polling happens from the slave or master
protected static String UNDEFINED_REVISION_VALUE
           
 
Fields inherited from class hudson.scm.SCM
PERMISSIONS, TAG
 
Constructor Summary
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, boolean useUpdate, boolean doRevert, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop, String excludedCommitMessages)
          Deprecated. as of 1.xxx
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, boolean useUpdate, boolean doRevert, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop, String excludedCommitMessages, String includedRegions)
          Deprecated. as of 1.23
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, boolean useUpdate, SubversionRepositoryBrowser browser, String excludedRegions)
          Deprecated. as of 1.315
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, boolean useUpdate, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop)
          Deprecated. as of 1.324
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, boolean useUpdate, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop, String excludedCommitMessages)
          Deprecated. as of 1.328
SubversionSCM(List<SubversionSCM.ModuleLocation> locations, WorkspaceUpdater workspaceUpdater, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop, String excludedCommitMessages, String includedRegions)
           
SubversionSCM(String svnUrl)
          Convenience constructor, especially during testing.
SubversionSCM(String[] remoteLocations, String[] localLocations, boolean useUpdate, SubversionRepositoryBrowser browser)
          Deprecated. as of 1.286
SubversionSCM(String[] remoteLocations, String[] localLocations, boolean useUpdate, SubversionRepositoryBrowser browser, String excludedRegions)
          Deprecated. as of 1.311
SubversionSCM(String[] remoteLocations, String[] localLocations, boolean useUpdate, SubversionRepositoryBrowser browser, String excludedRegions, String excludedUsers, String excludedRevprop)
          Deprecated. as of 1.315
SubversionSCM(String svnUrl, String local)
          Convenience constructor, especially during testing.
 
Method Summary
 void buildEnvVars(hudson.model.AbstractBuild<?,?> build, Map<String,String> env)
          Sets the SVN_REVISION environment variable during the build.
 hudson.scm.SCMRevisionState calcRevisionsFromBuild(hudson.model.AbstractBuild<?,?> build, hudson.Launcher launcher, hudson.model.TaskListener listener)
           
 boolean checkout(hudson.model.AbstractBuild build, hudson.Launcher launcher, hudson.FilePath workspace, hudson.model.BuildListener listener, File changelogFile)
           
protected  hudson.scm.PollingResult compareRemoteRevisionWith(hudson.model.AbstractProject<?,?> project, hudson.Launcher launcher, hudson.FilePath workspace, hudson.model.TaskListener listener, hudson.scm.SCMRevisionState _baseline)
           
 hudson.scm.ChangeLogParser createChangeLogParser()
           
static org.tmatesoft.svn.core.wc.SVNClientManager createSvnClientManager(hudson.model.AbstractProject context)
          Creates SVNClientManager for code running on the master.
static org.tmatesoft.svn.core.wc.SVNClientManager createSvnClientManager(org.tmatesoft.svn.core.auth.ISVNAuthenticationProvider authProvider)
          Creates SVNClientManager.
static void enableSshDebug(Level level)
          Enables trace logging of Ganymed SSH library.
 boolean equals(Object o)
           
 SubversionRepositoryBrowser getBrowser()
           
 SubversionSCM.DescriptorImpl getDescriptor()
           
 String getExcludedCommitMessages()
           
 String[] getExcludedCommitMessagesNormalized()
           
 String getExcludedRegions()
           
 String[] getExcludedRegionsNormalized()
           
 String getExcludedRevprop()
           
 String getExcludedUsers()
           
 Set<String> getExcludedUsersNormalized()
           
 String getIncludedRegions()
           
 String[] getIncludedRegionsNormalized()
           
 SubversionSCM.ModuleLocation[] getLocations()
          list of all configured svn locations
 SubversionSCM.ModuleLocation[] getLocations(hudson.model.AbstractBuild<?,?> build)
          list of all configured svn locations, expanded according to build parameters values;
 hudson.FilePath getModuleRoot(hudson.FilePath workspace)
           
 hudson.FilePath[] getModuleRoots(hudson.FilePath workspace)
           
 String getModules()
          Deprecated. as of 1.91. Use getLocations() instead.
static File getRevisionFile(hudson.model.AbstractBuild build)
          Gets the file that stores the revision.
static File getSubversionConfigDir()
          Return subversion configuration directory.
 WorkspaceUpdater getWorkspaceUpdater()
           
 int hashCode()
           
static void init()
           
static boolean isEqualsWithoutOrdering(Object[] array1, Object[] array2)
          Verify if two arrays of objects are equal without same order of elements.
 boolean repositoryLocationsNoLongerExist(hudson.model.AbstractBuild<?,?> build, hudson.model.TaskListener listener)
           
 boolean requiresWorkspaceForPolling()
          Polling can happen on the master and does not require a workspace.
 void setWorkspaceUpdater(WorkspaceUpdater workspaceUpdater)
           
 
Methods inherited from class hudson.scm.SCM
_calcRevisionsFromBuild, _for, all, createEmptyChangeLog, getApi, getEffectiveBrowser, getModuleRoot, getModuleRoots, getType, nullify, poll, pollChanges, processWorkspaceBeforeDeletion, supportsPolling
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

UNDEFINED_REVISION_VALUE

protected static final String UNDEFINED_REVISION_VALUE
See Also:
Constant Field Values

DEFAULT_TIMEOUT

public static int DEFAULT_TIMEOUT
Network timeout in milliseconds. The main point of this is to prevent infinite hang, so it should be a rather long value to avoid accidental time out problem.


POLL_FROM_MASTER

public static boolean POLL_FROM_MASTER
Property to control whether SCM polling happens from the slave or master

Constructor Detail

SubversionSCM

public SubversionSCM(String[] remoteLocations,
                     String[] localLocations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser)
Deprecated. as of 1.286


SubversionSCM

public SubversionSCM(String[] remoteLocations,
                     String[] localLocations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions)
Deprecated. as of 1.311


SubversionSCM

public SubversionSCM(String[] remoteLocations,
                     String[] localLocations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions,
                     String excludedUsers,
                     String excludedRevprop)
Deprecated. as of 1.315


SubversionSCM

public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions)
Deprecated. as of 1.315


SubversionSCM

public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions,
                     String excludedUsers,
                     String excludedRevprop)
Deprecated. as of 1.324


SubversionSCM

public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                     boolean useUpdate,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions,
                     String excludedUsers,
                     String excludedRevprop,
                     String excludedCommitMessages)
Deprecated. as of 1.328


SubversionSCM

public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                     boolean useUpdate,
                     boolean doRevert,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions,
                     String excludedUsers,
                     String excludedRevprop,
                     String excludedCommitMessages)
Deprecated. as of 1.xxx


SubversionSCM

public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                     boolean useUpdate,
                     boolean doRevert,
                     SubversionRepositoryBrowser browser,
                     String excludedRegions,
                     String excludedUsers,
                     String excludedRevprop,
                     String excludedCommitMessages,
                     String includedRegions)
Deprecated. as of 1.23


SubversionSCM

@DataBoundConstructor
public SubversionSCM(List<SubversionSCM.ModuleLocation> locations,
                                          WorkspaceUpdater workspaceUpdater,
                                          SubversionRepositoryBrowser browser,
                                          String excludedRegions,
                                          String excludedUsers,
                                          String excludedRevprop,
                                          String excludedCommitMessages,
                                          String includedRegions)

SubversionSCM

public SubversionSCM(String svnUrl)
Convenience constructor, especially during testing.


SubversionSCM

public SubversionSCM(String svnUrl,
                     String local)
Convenience constructor, especially during testing.

Method Detail

getModules

public String getModules()
Deprecated. as of 1.91. Use getLocations() instead.


getLocations

@Exported
public SubversionSCM.ModuleLocation[] getLocations()
list of all configured svn locations

Since:
1.91

getWorkspaceUpdater

@Exported
public WorkspaceUpdater getWorkspaceUpdater()

setWorkspaceUpdater

public void setWorkspaceUpdater(WorkspaceUpdater workspaceUpdater)

getLocations

public SubversionSCM.ModuleLocation[] getLocations(hudson.model.AbstractBuild<?,?> build)
list of all configured svn locations, expanded according to build parameters values;

Parameters:
build - If non-null, variable expansions are performed against the build parameters.
Since:
1.252

getBrowser

@Exported
public SubversionRepositoryBrowser getBrowser()
Overrides:
getBrowser in class hudson.scm.SCM

getExcludedRegions

@Exported
public String getExcludedRegions()

getExcludedRegionsNormalized

public String[] getExcludedRegionsNormalized()

getIncludedRegions

@Exported
public String getIncludedRegions()

getIncludedRegionsNormalized

public String[] getIncludedRegionsNormalized()

getExcludedUsers

@Exported
public String getExcludedUsers()

getExcludedUsersNormalized

public Set<String> getExcludedUsersNormalized()

getExcludedRevprop

@Exported
public String getExcludedRevprop()

getExcludedCommitMessages

@Exported
public String getExcludedCommitMessages()

getExcludedCommitMessagesNormalized

public String[] getExcludedCommitMessagesNormalized()

buildEnvVars

public void buildEnvVars(hudson.model.AbstractBuild<?,?> build,
                         Map<String,String> env)
Sets the SVN_REVISION environment variable during the build.

Overrides:
buildEnvVars in class hudson.scm.SCM

getSubversionConfigDir

public static File getSubversionConfigDir()
Return subversion configuration directory.

Returns:
directory.

requiresWorkspaceForPolling

public boolean requiresWorkspaceForPolling()
Polling can happen on the master and does not require a workspace.

Overrides:
requiresWorkspaceForPolling in class hudson.scm.SCM

checkout

public boolean checkout(hudson.model.AbstractBuild build,
                        hudson.Launcher launcher,
                        hudson.FilePath workspace,
                        hudson.model.BuildListener listener,
                        File changelogFile)
                 throws IOException,
                        InterruptedException
Specified by:
checkout in class hudson.scm.SCM
Throws:
IOException
InterruptedException

createSvnClientManager

public static org.tmatesoft.svn.core.wc.SVNClientManager createSvnClientManager(org.tmatesoft.svn.core.auth.ISVNAuthenticationProvider authProvider)
Creates SVNClientManager.

This method must be executed on the slave where svn operations are performed.

Parameters:
authProvider - The value obtained from SubversionSCM.DescriptorImpl.createAuthenticationProvider(AbstractProject). If the operation runs on slaves, (and properly remoted, if the svn operations run on slaves.)

createSvnClientManager

public static org.tmatesoft.svn.core.wc.SVNClientManager createSvnClientManager(hudson.model.AbstractProject context)
Creates SVNClientManager for code running on the master.

CAUTION: this code only works when invoked on master. On slaves, use createSvnClientManager(ISVNAuthenticationProvider) and get ISVNAuthenticationProvider from the master via remoting.


getRevisionFile

public static File getRevisionFile(hudson.model.AbstractBuild build)
Gets the file that stores the revision.


calcRevisionsFromBuild

public hudson.scm.SCMRevisionState calcRevisionsFromBuild(hudson.model.AbstractBuild<?,?> build,
                                                          hudson.Launcher launcher,
                                                          hudson.model.TaskListener listener)
                                                   throws IOException,
                                                          InterruptedException
Specified by:
calcRevisionsFromBuild in class hudson.scm.SCM
Throws:
IOException
InterruptedException

compareRemoteRevisionWith

protected hudson.scm.PollingResult compareRemoteRevisionWith(hudson.model.AbstractProject<?,?> project,
                                                             hudson.Launcher launcher,
                                                             hudson.FilePath workspace,
                                                             hudson.model.TaskListener listener,
                                                             hudson.scm.SCMRevisionState _baseline)
                                                      throws IOException,
                                                             InterruptedException
Specified by:
compareRemoteRevisionWith in class hudson.scm.SCM
Throws:
IOException
InterruptedException

createChangeLogParser

public hudson.scm.ChangeLogParser createChangeLogParser()
Specified by:
createChangeLogParser in class hudson.scm.SCM

getDescriptor

public SubversionSCM.DescriptorImpl getDescriptor()
Specified by:
getDescriptor in interface hudson.model.Describable<hudson.scm.SCM>
Overrides:
getDescriptor in class hudson.scm.SCM

getModuleRoot

public hudson.FilePath getModuleRoot(hudson.FilePath workspace)
Overrides:
getModuleRoot in class hudson.scm.SCM

getModuleRoots

public hudson.FilePath[] getModuleRoots(hudson.FilePath workspace)
Overrides:
getModuleRoots in class hudson.scm.SCM

repositoryLocationsNoLongerExist

public boolean repositoryLocationsNoLongerExist(hudson.model.AbstractBuild<?,?> build,
                                                hudson.model.TaskListener listener)

init

public static void init()

enableSshDebug

public static void enableSshDebug(Level level)
Enables trace logging of Ganymed SSH library.

Intended to be invoked from Groovy console.


equals

public boolean equals(Object o)
Overrides:
equals in class Object

isEqualsWithoutOrdering

public static boolean isEqualsWithoutOrdering(Object[] array1,
                                              Object[] array2)
Verify if two arrays of objects are equal without same order of elements. TODO: Remove this methods

Parameters:
array1 - first array.
array2 - second array.
Returns:
true if two arrays equals and false in other way.

hashCode

public int hashCode()
Overrides:
hashCode in class Object


Copyright © 2004-2013 Hudson. All Rights Reserved.