public class ExceptionThrowingItemReaderProxy<T> extends java.lang.Object implements ItemReader<T>
ItemReader
that throws exception on a given record number
(useful for testing restart).Constructor and Description |
---|
ExceptionThrowingItemReaderProxy() |
Modifier and Type | Method and Description |
---|---|
T |
read()
Reads a piece of input data and advance to the next one.
|
void |
setDelegate(ItemReader<T> delegate) |
void |
setThrowExceptionOnRecordNumber(int throwExceptionOnRecordNumber) |
public void setThrowExceptionOnRecordNumber(int throwExceptionOnRecordNumber)
throwExceptionOnRecordNumber
- The number of record on which
exception should be thrownpublic T read() throws java.lang.Exception
ItemReader
null
at the end of the input
data set. In a transactional setting, caller might get the same item
twice from successive calls (or otherwise), if the first call was in a
transaction that rolled back.read
in interface ItemReader<T>
null
if the data source is
exhaustedParseException
- if there is a problem parsing the current record
(but the next one may still be valid)NonTransientResourceException
- if there is a fatal exception in
the underlying resource. After throwing this exception implementations
should endeavour to return null from subsequent calls to read.UnexpectedInputException
- if there is an uncategorised problem
with the input data. Assume potentially transient, so subsequent calls to
read might succeed.java.lang.Exception
- if an there is a non-specific error.public void setDelegate(ItemReader<T> delegate)