public class JobLauncherTestUtils
extends java.lang.Object
 Utility class for testing batch jobs. It provides methods for launching an
 entire AbstractJob, allowing for end to end testing of individual
 steps, without having to run every step in the job. Any test classes using
 this utility can set up an instance in the ApplicationContext as part
 of the Spring test framework.
 
 This class also provides the ability to run Steps from a
 FlowJob or SimpleJob individually. By launching Steps
 within a Job on their own, end to end testing of individual steps can
 be performed without having to run every step in the job.
 
 It should be noted that using any of the methods that don't contain
 JobParameters in their signature, will result in one being created
 with a random number of type long as a parameter. This will ensure
 restartability when no parameters are provided.
 
| Modifier and Type | Field and Description | 
|---|---|
| protected org.apache.commons.logging.Log | loggerLogger | 
| Constructor and Description | 
|---|
| JobLauncherTestUtils() | 
| Modifier and Type | Method and Description | 
|---|---|
| Job | getJob() | 
| JobLauncher | getJobLauncher() | 
| JobRepository | getJobRepository() | 
| protected StepRunner | getStepRunner()Convenient method for subclasses to grab a  StepRunnerfor running
 steps by name. | 
| JobParameters | getUniqueJobParameters() | 
| JobExecution | launchJob()Launch the entire job, including all steps. | 
| JobExecution | launchJob(JobParameters jobParameters)Launch the entire job, including all steps | 
| JobExecution | launchStep(java.lang.String stepName)Launch just the specified step in the job. | 
| JobExecution | launchStep(java.lang.String stepName,
          ExecutionContext jobExecutionContext)Launch just the specified step in the job. | 
| JobExecution | launchStep(java.lang.String stepName,
          JobParameters jobParameters)Launch just the specified step in the job. | 
| JobExecution | launchStep(java.lang.String stepName,
          JobParameters jobParameters,
          ExecutionContext jobExecutionContext)Launch just the specified step in the job. | 
| void | setJob(Job job)The Job instance that can be manipulated (e.g. | 
| void | setJobLauncher(JobLauncher jobLauncher)A  JobLauncherinstance that can be used to launch jobs. | 
| void | setJobRepository(JobRepository jobRepository)The  JobRepositoryto use for creating newJobExecutioninstances. | 
@Autowired public void setJob(Job job)
job - the AbstractJob to use@Autowired public void setJobRepository(JobRepository jobRepository)
JobRepository to use for creating new JobExecution
 instances.jobRepository - a JobRepositorypublic JobRepository getJobRepository()
public Job getJob()
@Autowired public void setJobLauncher(JobLauncher jobLauncher)
JobLauncher instance that can be used to launch jobs.jobLauncher - a job launcherpublic JobLauncher getJobLauncher()
public JobExecution launchJob() throws java.lang.Exception
java.lang.Exception - thrown if error occurs launching the job.public JobExecution launchJob(JobParameters jobParameters) throws java.lang.Exception
jobParameters - instance of JobParameters.java.lang.Exception - thrown if error occurs launching the job.public JobParameters getUniqueJobParameters()
long, to ensure that the job instance will be unique.protected StepRunner getStepRunner()
StepRunner for running
 steps by name.StepRunnerpublic JobExecution launchStep(java.lang.String stepName)
stepName - The name of the step to launchpublic JobExecution launchStep(java.lang.String stepName, ExecutionContext jobExecutionContext)
stepName - The name of the step to launchjobExecutionContext - An ExecutionContext whose values will be
 loaded into the Job ExecutionContext prior to launching the step.public JobExecution launchStep(java.lang.String stepName, JobParameters jobParameters)
stepName - The name of the step to launchjobParameters - The JobParameters to use during the launchpublic JobExecution launchStep(java.lang.String stepName, JobParameters jobParameters, @Nullable ExecutionContext jobExecutionContext)
stepName - The name of the step to launchjobParameters - The JobParameters to use during the launchjobExecutionContext - An ExecutionContext whose values will be
 loaded into the Job ExecutionContext prior to launching the step.