Package com.atlassian.bamboo.plan
Class NonBlockingPlanExecutionServiceImpl
java.lang.Object
com.atlassian.bamboo.plan.NonBlockingPlanExecutionServiceImpl
- All Implemented Interfaces:
NonBlockingPlanExecutionService
public class NonBlockingPlanExecutionServiceImpl
extends Object
implements NonBlockingPlanExecutionService
-
Field Summary
Modifier and TypeFieldDescriptionprotected final EventLoggingThreadPoolExecutor
protected final PlanExecutionLaunchControl
-
Constructor Summary
ModifierConstructorDescriptionNonBlockingPlanExecutionServiceImpl
(PlanExecutionManager planExecutionManager) protected
NonBlockingPlanExecutionServiceImpl
(PlanExecutionManager planExecutionManager, int maximumThreadCount, long threadIdleTimeout) protected
NonBlockingPlanExecutionServiceImpl
(PlanExecutionManager planExecutionManager, EventLoggingThreadPoolExecutor executor) -
Method Summary
Modifier and TypeMethodDescriptionvoid
enqueueTrigger
(@NotNull Triggerable triggerable, @NotNull Long triggerId, @NotNull BuildDetectionAction buildDetectionAction) @NotNull ExecutorStats
Stats for the underlyingThreadPoolExecutor
@NotNull QueueActivityStatsDto
Gets analytical data from queue activity tracker and bring its initial state - start data collecting from scratch.shutdown()
Stop accepting any more trigger requests.@Nullable Future<ExecutionRequestResult>
tryToStart
(@NotNull Triggerable triggerable, @NotNull BuildDetectionAction buildDetectionAction)
-
Field Details
-
planExecutionLaunchControl
-
executor
-
-
Constructor Details
-
NonBlockingPlanExecutionServiceImpl
-
NonBlockingPlanExecutionServiceImpl
protected NonBlockingPlanExecutionServiceImpl(PlanExecutionManager planExecutionManager, int maximumThreadCount, long threadIdleTimeout) -
NonBlockingPlanExecutionServiceImpl
protected NonBlockingPlanExecutionServiceImpl(PlanExecutionManager planExecutionManager, EventLoggingThreadPoolExecutor executor)
-
-
Method Details
-
enqueueTrigger
public void enqueueTrigger(@NotNull @NotNull Triggerable triggerable, @NotNull @NotNull Long triggerId, @NotNull @NotNull BuildDetectionAction buildDetectionAction) Description copied from interface:NonBlockingPlanExecutionService
Submits a background task to runPlanExecutionManager.start(com.atlassian.bamboo.plan.cache.ImmutableChain, com.atlassian.bamboo.build.BuildDetectionAction, com.atlassian.bamboo.util.AcquisitionPolicy)
. Only oneAcquisitionPolicy.IMMEDIATE
per planKey + triggerId combination will be queued at any point in time. The task are not guaranteed to be run, they might get dropped ifNonBlockingPlanExecutionService.tryToStart(Triggerable, BuildDetectionAction)
is called. Rationale is: conditional triggers won't start anyway if there's a 'guaranteed' build run.To be used with automatic triggers: any auto Trigger can have Trigger Conditions defined
- Specified by:
enqueueTrigger
in interfaceNonBlockingPlanExecutionService
-
tryToStart
@Nullable public @Nullable Future<ExecutionRequestResult> tryToStart(@NotNull @NotNull Triggerable triggerable, @NotNull @NotNull BuildDetectionAction buildDetectionAction) Description copied from interface:NonBlockingPlanExecutionService
Submits a background task to runPlanExecutionManager.start(com.atlassian.bamboo.plan.cache.ImmutableChain, com.atlassian.bamboo.build.BuildDetectionAction, com.atlassian.bamboo.util.AcquisitionPolicy)
. The task usesAcquisitionPolicy.WAIT
. To be used for triggers that are 'unconditional'. In other words, the method should be used for cases where build absolutely, positively needs to trigger (unless encountering internal error or hitting concurrent build limit)- Specified by:
tryToStart
in interfaceNonBlockingPlanExecutionService
- Returns:
-
shutdown
Description copied from interface:NonBlockingPlanExecutionService
Stop accepting any more trigger requests.- Specified by:
shutdown
in interfaceNonBlockingPlanExecutionService
-
getExecutorStats
Description copied from interface:NonBlockingPlanExecutionService
Stats for the underlyingThreadPoolExecutor
- Specified by:
getExecutorStats
in interfaceNonBlockingPlanExecutionService
- Returns:
-
getQueueActivityStatsAndRestoreToInitialState
Description copied from interface:NonBlockingPlanExecutionService
Gets analytical data from queue activity tracker and bring its initial state - start data collecting from scratch.- Specified by:
getQueueActivityStatsAndRestoreToInitialState
in interfaceNonBlockingPlanExecutionService
- Returns:
- QueueActivityStatsDto with stat amounts
-