Class StepExecutionSimpleCompletionPolicy
java.lang.Object
org.springframework.batch.core.resource.StepExecutionSimpleCompletionPolicy
- All Implemented Interfaces:
StepExecutionListener
,StepListener
,CompletionPolicy
public class StepExecutionSimpleCompletionPolicy
extends Object
implements StepExecutionListener, CompletionPolicy
A CompletionPolicy
that picks up a commit interval from JobParameters
by listening to the start of a step. Use anywhere that a CompletionPolicy
can
be used (usually at the chunk level in a step), and inject as a
StepExecutionListener
into the surrounding step. N.B. only after the step has
started will the completion policy be usable.
It is easier and probably preferable to simply declare the chunk with a commit-interval
that is a late-binding expression (e.g.
#{jobParameters['commit.interval']}
). That feature is available from of
Spring Batch 2.1.7.
- Author:
- Dave Syer, Mahmoud Ben Hassine
- See Also:
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
beforeStep
(StepExecution stepExecution) Set up aSimpleCompletionPolicy
with a commit interval taken from theJobParameters
.boolean
isComplete
(RepeatContext context) Allow policy to signal completion according to internal state, without having to wait for the callback to complete.boolean
isComplete
(RepeatContext context, RepeatStatus result) Determine whether a batch is complete given the latest result from the callback.void
setKeyName
(String keyName) Public setter for the key name of a Long value in theJobParameters
that will contain a commit interval.start
(RepeatContext parent) Create a new context for the execution of a batch.toString()
Delegates to the wrappedCompletionPolicy
if set, otherwise returns the value ofsetKeyName(String)
.void
update
(RepeatContext context) Give implementations the opportunity to update the state of the current batch.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.springframework.batch.core.StepExecutionListener
afterStep
-
Constructor Details
-
StepExecutionSimpleCompletionPolicy
public StepExecutionSimpleCompletionPolicy()
-
-
Method Details
-
setKeyName
Public setter for the key name of a Long value in theJobParameters
that will contain a commit interval. Defaults to "commit.interval".- Parameters:
keyName
- the keyName to set
-
beforeStep
Set up aSimpleCompletionPolicy
with a commit interval taken from theJobParameters
. If there is a Long parameter with the given key name, the intValue of this parameter is used. If not an exception will be thrown.- Specified by:
beforeStep
in interfaceStepExecutionListener
- Parameters:
stepExecution
- instance ofStepExecution
.- See Also:
-
isComplete
Description copied from interface:CompletionPolicy
Determine whether a batch is complete given the latest result from the callback. If this method returns true thenCompletionPolicy.isComplete(RepeatContext)
should also (but not necessarily vice versa, since the answer here depends on the result).- Specified by:
isComplete
in interfaceCompletionPolicy
- Parameters:
context
- the current batch context.result
- the result of the latest batch item processing.- Returns:
- true if the commit interval has been reached or the result indicates completion
- See Also:
-
isComplete
Description copied from interface:CompletionPolicy
Allow policy to signal completion according to internal state, without having to wait for the callback to complete.- Specified by:
isComplete
in interfaceCompletionPolicy
- Parameters:
context
- the current batch context.- Returns:
- if the commit interval has been reached
- See Also:
-
start
Description copied from interface:CompletionPolicy
Create a new context for the execution of a batch. N.B. implementations should not return the parent from this method - they must create a new context to meet the specific needs of the policy. The best way to do this might be to override an existing implementation and use theRepeatContext
to store state in its attributes.- Specified by:
start
in interfaceCompletionPolicy
- Parameters:
parent
- the current context if one is already in progress.- Returns:
- a new
RepeatContext
- See Also:
-
update
Description copied from interface:CompletionPolicy
Give implementations the opportunity to update the state of the current batch. Will be called once per callback, after it has been launched, but not necessarily after it completes (if the batch is asynchronous).- Specified by:
update
in interfaceCompletionPolicy
- Parameters:
context
- the value returned by start.- See Also:
-
toString
Delegates to the wrappedCompletionPolicy
if set, otherwise returns the value ofsetKeyName(String)
.
-