Package com.atlassian.bamboo.task
Interface TaskManager
- All Known Implementing Classes:
TaskManagerImpl
@PublicApi
public interface TaskManager
- Since:
- 3.1
-
Method Summary
Modifier and TypeMethodDescriptionvoid
calculateRequirementsForTaskDefinition
(@NotNull Job job, @NotNull TaskDefinition taskDefinition) Attempts to addRequirement
s to the specifiedBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculatedvoid
calculateRequirementsForTaskDefinition
(@NotNull Job job, @NotNull TaskDefinition taskDefinition, boolean dockerPipelinesEnabled) Attempts to addRequirement
s to the specifiedBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculatedvoid
calculateRequirementsForTaskDefinition
(@NotNull RequirementSet requirementSet, @NotNull TaskDefinition taskDefinition, Supplier<Set<Requirement>> requirementSupplier) Deprecated.void
calculateRequirementsForTaskDefinition
(@NotNull RequirementSet requirementSet, @NotNull TaskDefinition taskDefinition, Supplier<Set<Requirement>> requirementSupplier, boolean dockerPipelinesEnabled) Attempts to addRequirement
s to the specifiedRequirementSet
.@NotNull List<TaskModuleDescriptor>
@NotNull List<TaskModuleDescriptor>
@NotNull List<TaskModuleDescriptor>
getCapabilitiesWithExecutables
(@NotNull Set<String> executableType) Returns a set of capabilities that have executable types defined for them in the system.Deprecated.since 8.0 labels are not unique across different executable types.Returns a map of currently available "configured" executables - identified by a label.@Nullable TaskModuleDescriptor
getTaskDescriptor
(@Nullable String pluginKey) Get the task type descriptor matching a particular plugin key.@NotNull Collection<Requirement>
getTasksRequirements
(@NotNull Job job) ReturnRequirement
s for all tasks ofBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
void
recalculateRequirementsForJob
(Job job, boolean dockerPipelinesEnabled) Recalculates requirements for job with given docker pipelines flag.void
removeRequirementsForTaskDefinition
(@NotNull Buildable buildable, @NotNull TaskDefinition taskDefinition) Removes all theRequirement
s that belong to theTaskDefinition
void
removeRequirementsForTaskDefinition
(@NotNull RequirementSet requirementSet, @NotNull TaskDefinition taskDefinition) Removes all theRequirement
s that belong to theTaskDefinition
boolean
taskProducesTestResults
(@NotNull TaskDefinition taskDefinition) Return true iff task defined inTaskDefinition
is configured to produce test results.void
updateRepositoryIdsInTask
(@NotNull TaskDefinition taskDefinition, @NotNull Map<Long, Long> repositoryIdChanges) Updates task configurations affected by repository edition.void
updateWorkingDirSelectors
(@NotNull ImmutableBuildable job, @NotNull BuildDefinition buildDefinition, @NotNull Map<Long, Long> repositoryIdsChanges) Calculates id of the repository that defines working directory after repository or task edition.
-
Method Details
-
getAvailableTaskDescriptors
- Returns:
- Provides a list of available tasks types. Returns both Build Tasks and DeploymentTasks
-
getAvailableBuildTaskDescriptors
- Returns:
- Provides a list of available build task types.
- Since:
- 5.0
-
getAvailableDeploymentTaskDescriptors
- Returns:
- Provides a list of available deployment task types.
- Since:
- 5.0
-
getTaskDescriptor
Get the task type descriptor matching a particular plugin key.- Parameters:
pluginKey
- - key to match- Returns:
- TaskModuleDescriptor matching the given key if it exists. Null if the plugin can not be found.
-
calculateRequirementsForTaskDefinition
void calculateRequirementsForTaskDefinition(@NotNull @NotNull Job job, @NotNull @NotNull TaskDefinition taskDefinition, boolean dockerPipelinesEnabled) Attempts to addRequirement
s to the specifiedBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculated- Since:
- 9.3
-
calculateRequirementsForTaskDefinition
void calculateRequirementsForTaskDefinition(@NotNull @NotNull Job job, @NotNull @NotNull TaskDefinition taskDefinition) Attempts to addRequirement
s to the specifiedBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculated- Parameters:
job
-taskDefinition
-
-
calculateRequirementsForTaskDefinition
@Deprecated void calculateRequirementsForTaskDefinition(@NotNull @NotNull RequirementSet requirementSet, @NotNull @NotNull TaskDefinition taskDefinition, Supplier<Set<Requirement>> requirementSupplier) Deprecated.Attempts to addRequirement
s to the specifiedRequirementSet
. How to get the requirements from the task Definition is determined by the supplier. If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculated- Parameters:
requirementSet
- to add requirements update requirements intaskDefinition
- to calculate requirements from
-
calculateRequirementsForTaskDefinition
void calculateRequirementsForTaskDefinition(@NotNull @NotNull RequirementSet requirementSet, @NotNull @NotNull TaskDefinition taskDefinition, Supplier<Set<Requirement>> requirementSupplier, boolean dockerPipelinesEnabled) Attempts to addRequirement
s to the specifiedRequirementSet
. How to get the requirements from the task Definition is determined by the supplier. If requirements are already present for the specifiedTaskDefinition
they will be removed and recalculated. If docker pipelines is enabled than requirements from requirementSupplier won't be added toRequirementSet
, instead of this docker requirement will be added.- Parameters:
requirementSet
- to add requirements update requirements intaskDefinition
- to calculate requirements fromdockerPipelinesEnabled
- flag for docker pipelines
-
removeRequirementsForTaskDefinition
void removeRequirementsForTaskDefinition(@NotNull @NotNull Buildable buildable, @NotNull @NotNull TaskDefinition taskDefinition) Removes all theRequirement
s that belong to theTaskDefinition
- Parameters:
buildable
- to remove requirements fromtaskDefinition
- that was removed
-
removeRequirementsForTaskDefinition
void removeRequirementsForTaskDefinition(@NotNull @NotNull RequirementSet requirementSet, @NotNull @NotNull TaskDefinition taskDefinition) Removes all theRequirement
s that belong to theTaskDefinition
- Parameters:
requirementSet
- to remove requirements fromtaskDefinition
- that was removed
-
getTasksRequirements
ReturnRequirement
s for all tasks ofBuildable
if theTaskConfigurator
is an implementor ofBuildTaskRequirementSupport
- Parameters:
job
-- Returns:
- requirements
- Throws:
IllegalStateException
-
taskProducesTestResults
Return true iff task defined inTaskDefinition
is configured to produce test results.- Parameters:
taskDefinition
-- Returns:
- producesTestResults
-
getExecutableLabelTypeMap
Deprecated.since 8.0 labels are not unique across different executable types. Use {getExecutableLabelTypesMap()
} instead.Returns a map of currently available "configured" executables - uniquely identified by a label.Maps label -> taskExecutableType.getExecutableKey().
The executables are backed by available capabilities system wide, filtered by executables which are actually activated in the plugin system.
- Returns:
- executableTypeLabelMaps
-
getExecutableLabelTypesMap
Returns a map of currently available "configured" executables - identified by a label.Maps label -> collection of taskExecutableType.getExecutableKey().
The executables are backed by available capabilities system wide, filtered by executables which are actually activated in the plugin system.
- Returns:
- executableTypeLabelMultiMaps
-
updateRepositoryIdsInTask
void updateRepositoryIdsInTask(@NotNull @NotNull TaskDefinition taskDefinition, @NotNull @NotNull Map<Long, Long> repositoryIdChanges) Updates task configurations affected by repository edition.- Parameters:
taskDefinition
-repositoryIdChanges
- mapping between old and new repositories ids- Since:
- 4.3
-
updateWorkingDirSelectors
void updateWorkingDirSelectors(@NotNull @NotNull ImmutableBuildable job, @NotNull @NotNull BuildDefinition buildDefinition, @NotNull @NotNull Map<Long, Long> repositoryIdsChanges) Calculates id of the repository that defines working directory after repository or task edition.- Parameters:
job
- affected jobbuildDefinition
-repositoryIdsChanges
- mapping between old and new repositories ids
-
getCapabilitiesWithExecutables
Returns a set of capabilities that have executable types defined for them in the system. -
recalculateRequirementsForJob
Recalculates requirements for job with given docker pipelines flag.- Parameters:
job
-dockerPipelinesEnabled
-- Since:
- 6.4
-
calculateRequirementsForTaskDefinition(RequirementSet, TaskDefinition, Supplier, boolean)
instead