Package hudson.model
Class Executor
java.lang.Object
java.lang.Thread
hudson.model.Executor
- All Implemented Interfaces:
- ModelObject,- Runnable,- IExecutor
- Direct Known Subclasses:
- OneOffExecutor
Thread that executes builds.
 Since 1.536, 
Executors start threads on-demand.
 Callers should use isActive() instead of Thread.isAlive().
- Author:
- Kohsuke Kawaguchi
- 
Nested Class SummaryNested classes/interfaces inherited from class java.lang.ThreadThread.State, Thread.UncaughtExceptionHandler
- 
Field SummaryFieldsFields inherited from class java.lang.ThreadMAX_PRIORITY, MIN_PRIORITY, NORM_PRIORITY
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidcompletedAsynchronous(Throwable error) static ExecutorReturns the executor of the current thread or null if current thread is not an executor.org.kohsuke.stapler.HttpResponsedoStop()Stops the current build.
 You can usedoStopBuild(String)instead to ensure what will be interrupted is actually what you want to interrupt.voiddoStop(org.kohsuke.stapler.StaplerRequest req, org.kohsuke.stapler.StaplerResponse rsp) Deprecated.org.kohsuke.stapler.HttpResponsedoStopBuild(String runExtId) Stops the current build, if matching the specified external id (or no id is specified, or the currentQueue.Executableis not aRun).org.kohsuke.stapler.HttpResponsedoYank()Deprecated.now a no-opgetApi()Exposes the executor to the remote API.If currently running in asynchronous mode, returns that handle.Deprecated.no longer usedReturns causes of interruption.Returns the current build this executor is running.Same asgetCurrentExecutable()but checksItem.READ.If current executable isAbstractBuild, return the workspace that this executor is using, or null if the build hasn't gotten to that point yet.Returns the currentWorkUnit(ofthe current executable) that this executor is running.Human readable name of the Jenkins executor.longGets the elapsed time since the build has started.static longDeprecated.callQueue.Executable.getEstimatedDuration()directlyComputes a human-readable text that shows the expected remaining time until the build completes.longThe same asgetEstimatedRemainingTime()but return it as a number of milli-seconds.longReturns when this executor started or should start being idle.intGets the executor number that uniquely identifies it among otherIExecutors for the same computer.getOwner()intReturns the progress of the current build in the number between 0-100.longReturns the number of milli-seconds the currently executing job spent in the queue waiting for an available executor.booleanChecks if the current user has a permission to stop this build.voidvoidInterrupt the execution, but instead of marking the build as aborted, mark it as specified result.voidinterrupt(Result result, CauseOfInterruption... causes) Interrupt the execution.booleanisActive()Check if executor is ready to accept tasks.booleanisBusy()The opposite ofisIdle()— the executor is doing some work.booleanIf this executor is running anAsynchronousExecutionand that execution wants to hide the display cell for the executor (because there is another executor displaying the job progress and we don't want to confuse the user) then this method will returnfalseto indicate toexecutors.jellythat the executor cell should be hidden.booleanisIdle()Returns true if thisIExecutoris ready for action.booleanReturns true if the current build is likely stuck.booleanReturns true if this executor is waiting for a task to execute.<T> TnewImpersonatingProxy(Class<T> type, T core) Creates a proxy object that executes the callee in the context that impersonates this executor.static Executorof(Queue.Executable executable) Finds the executor currently running a given process.voidrecordCauseOfInterruption(Run<?, ?> build, TaskListener listener) report cause of interruption and record it to the build, if available.voidrun()voidstart()Can't start executor like you normally start a thread.Methods inherited from class java.lang.ThreadactiveCount, checkAccess, clone, countStackFrames, currentThread, dumpStack, enumerate, getAllStackTraces, getContextClassLoader, getDefaultUncaughtExceptionHandler, getId, getName, getPriority, getStackTrace, getState, getThreadGroup, getUncaughtExceptionHandler, holdsLock, interrupted, isAlive, isDaemon, isInterrupted, join, join, join, onSpinWait, resume, setContextClassLoader, setDaemon, setDefaultUncaughtExceptionHandler, setName, setPriority, setUncaughtExceptionHandler, sleep, sleep, stop, suspend, toString, yieldMethods inherited from class java.lang.Objectequals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface jenkins.model.IExecutorgetParentTask, getTimestampString
- 
Field Details- 
owner
 
- 
- 
Constructor Details- 
Executor
 
- 
- 
Method Details- 
interruptpublic void interrupt()
- 
interruptInterrupt the execution, but instead of marking the build as aborted, mark it as specified result.- Since:
- 1.417
 
- 
interruptInterrupt the execution. Mark the cause and the status accordingly.
- 
abortResult
- 
recordCauseOfInterruptionreport cause of interruption and record it to the build, if available.- Since:
- 1.425
 
- 
runpublic void run()
- 
completedAsynchronous@Restricted(org.kohsuke.accmod.restrictions.NoExternalUse.class) public void completedAsynchronous(@CheckForNull Throwable error) 
- 
getCurrentExecutableReturns the current build this executor is running.- Specified by:
- getCurrentExecutablein interface- IExecutor
- Returns:
- null if the executor is idle.
 
- 
getCurrentExecutableForApi@Exported(name="currentExecutable") @Restricted(org.kohsuke.accmod.restrictions.DoNotUse.class) public Queue.Executable getCurrentExecutableForApi()Same asgetCurrentExecutable()but checksItem.READ.
- 
getCausesOfInterruptionReturns causes of interruption.- Returns:
- Unmodifiable collection of causes of interruption.
- Since:
- 1.617
 
- 
getCurrentWorkUnitDescription copied from interface:IExecutorReturns the currentWorkUnit(ofthe current executable) that this executor is running.- Specified by:
- getCurrentWorkUnitin interface- IExecutor
- Returns:
- null if the executor is idle.
 
- 
getCurrentWorkspaceIf current executable isAbstractBuild, return the workspace that this executor is using, or null if the build hasn't gotten to that point yet.
- 
getDisplayNameHuman readable name of the Jenkins executor. For the Java thread name useThread.getName().- Specified by:
- getDisplayNamein interface- IExecutor
- Specified by:
- getDisplayNamein interface- ModelObject
- Returns:
- the current display name of the executor. Usually the name of the executable.
 
- 
getNumber@Exported public int getNumber()Description copied from interface:IExecutorGets the executor number that uniquely identifies it among otherIExecutors for the same computer.
- 
isIdle@Exported public boolean isIdle()Description copied from interface:IExecutorReturns true if thisIExecutoris ready for action.
- 
isBusypublic boolean isBusy()The opposite ofisIdle()— the executor is doing some work.
- 
isActivepublic boolean isActive()Check if executor is ready to accept tasks. This method becomes the critical one since 1.536, which introduces the on-demand creation of executor threads. Callers should use this method instead ofThread.isAlive(), which would be incorrect for non-started threads or runningAsynchronousExecution.- Returns:
- true if the executor is available for tasks (usually true)
- Since:
- 1.536
 
- 
getAsynchronousExecutionIf currently running in asynchronous mode, returns that handle.- Since:
- 1.607
 
- 
isDisplayCellpublic boolean isDisplayCell()If this executor is running anAsynchronousExecutionand that execution wants to hide the display cell for the executor (because there is another executor displaying the job progress and we don't want to confuse the user) then this method will returnfalseto indicate toexecutors.jellythat the executor cell should be hidden.- Returns:
- trueiff the- executorCell.jellyfor this- Executorshould be displayed in- executors.jelly.
- Since:
- 1.607
- See Also:
 
- 
isParkingpublic boolean isParking()Returns true if this executor is waiting for a task to execute.
- 
getCauseOfDeathDeprecated.no longer used
- 
getProgress@Exported public int getProgress()Description copied from interface:IExecutorReturns the progress of the current build in the number between 0-100.- Specified by:
- getProgressin interface- IExecutor
- Returns:
- -1 if it's impossible to estimate the progress.
 
- 
isLikelyStuck@Exported public boolean isLikelyStuck()Description copied from interface:IExecutorReturns true if the current build is likely stuck.This is a heuristics based approach, but if the build is suspiciously taking for a long time, this method returns true. - Specified by:
- isLikelyStuckin interface- IExecutor
 
- 
getElapsedTimepublic long getElapsedTime()Description copied from interface:IExecutorGets the elapsed time since the build has started.- Specified by:
- getElapsedTimein interface- IExecutor
- Returns:
- the number of milliseconds since the build has started.
 
- 
getTimeSpentInQueuepublic long getTimeSpentInQueue()Returns the number of milli-seconds the currently executing job spent in the queue waiting for an available executor. This excludes the quiet period time of the job.- Since:
- 1.440
 
- 
getEstimatedRemainingTimeDescription copied from interface:IExecutorComputes a human-readable text that shows the expected remaining time until the build completes.- Specified by:
- getEstimatedRemainingTimein interface- IExecutor
 
- 
getEstimatedRemainingTimeMillispublic long getEstimatedRemainingTimeMillis()The same asgetEstimatedRemainingTime()but return it as a number of milli-seconds.
- 
startpublic void start()Can't start executor like you normally start a thread.
- 
doStop@Deprecated public void doStop(org.kohsuke.stapler.StaplerRequest req, org.kohsuke.stapler.StaplerResponse rsp) throws IOException, javax.servlet.ServletException Deprecated.as of 1.489 UsedoStop()ordoStopBuild(String).- Throws:
- IOException
- javax.servlet.ServletException
 
- 
doStoppublic org.kohsuke.stapler.HttpResponse doStop()Stops the current build.
 You can usedoStopBuild(String)instead to ensure what will be interrupted is actually what you want to interrupt.- Since:
- 1.489
- See Also:
 
- 
doStopBuild@Restricted(org.kohsuke.accmod.restrictions.NoExternalUse.class) public org.kohsuke.stapler.HttpResponse doStopBuild(@CheckForNull @QueryParameter(fixEmpty=true) String runExtId) Stops the current build, if matching the specified external id (or no id is specified, or the currentQueue.Executableis not aRun).- Parameters:
- runExtId- if not null, the externalizable id (- Run.getExternalizableId()) of the build the user expects to interrupt
- Since:
- 2.209
 
- 
doYankDeprecated.now a no-op
- 
hasStopPermissionpublic boolean hasStopPermission()Description copied from interface:IExecutorChecks if the current user has a permission to stop this build.- Specified by:
- hasStopPermissionin interface- IExecutor
 
- 
getOwner
- 
getIdleStartMillisecondspublic long getIdleStartMilliseconds()Returns when this executor started or should start being idle.
- 
getApiExposes the executor to the remote API.
- 
newImpersonatingProxyCreates a proxy object that executes the callee in the context that impersonates this executor. Useful to export an object to a remote channel.
- 
currentExecutorReturns the executor of the current thread or null if current thread is not an executor.
- 
ofFinds the executor currently running a given process.- Parameters:
- executable- a possibly running executable
- Returns:
- the executor (possibly a OneOffExecutor) whosegetCurrentExecutable()matches that, or null if it could not be found (for example because the execution has already completed)
- Since:
- 1.607
 
- 
getEstimatedDurationForDeprecated.callQueue.Executable.getEstimatedDuration()directly
 
- 
doStop()ordoStopBuild(String).