Class JobLauncherTestUtils
 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.
 
- Since:
- 2.1
- Author:
- Lucas Ward, Dan Garrette, Dave Syer, Mahmoud Ben Hassine
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptiongetJob()protected StepRunnerConvenient method for subclasses to grab aStepRunnerfor running steps by name.Launch the entire job, including all steps.launchJob(JobParameters jobParameters) Launch the entire job, including all stepslaunchStep(String stepName) Launch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME.launchStep(String stepName, JobParameters jobParameters) Launch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME.launchStep(String stepName, JobParameters jobParameters, ExecutionContext jobExecutionContext) Launch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME.launchStep(String stepName, ExecutionContext jobExecutionContext) Launch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME.voidThe Job instance that can be manipulated (e.g.voidsetJobLauncher(JobLauncher jobLauncher) AJobLauncherinstance that can be used to launch jobs.voidsetJobRepository(JobRepository jobRepository) TheJobRepositoryto use for creating newJobExecutioninstances.
- 
Field Details- 
loggerprotected final org.apache.commons.logging.Log loggerLogger
 
- 
- 
Constructor Details- 
JobLauncherTestUtilspublic JobLauncherTestUtils()
 
- 
- 
Method Details- 
setJobThe Job instance that can be manipulated (e.g. launched) in this utility.- Parameters:
- job- the- AbstractJobto use
 
- 
setJobRepositoryTheJobRepositoryto use for creating newJobExecutioninstances.- Parameters:
- jobRepository- a- JobRepository
 
- 
getJobRepository- Returns:
- the job repository
 
- 
getJob- Returns:
- the job
 
- 
setJobLauncherAJobLauncherinstance that can be used to launch jobs.- Parameters:
- jobLauncher- a job launcher
 
- 
getJobLauncher- Returns:
- the job launcher
 
- 
launchJobLaunch the entire job, including all steps.- Returns:
- JobExecution, so that the test can validate the exit status
- Throws:
- Exception- thrown if error occurs launching the job.
 
- 
launchJobLaunch the entire job, including all steps- Parameters:
- jobParameters- instance of- JobParameters.
- Returns:
- JobExecution, so that the test can validate the exit status
- Throws:
- Exception- thrown if error occurs launching the job.
 
- 
getUniqueJobParameters- Returns:
- a new JobParameters object containing only a parameter with a random number
 of type long, to ensure that the job instance will be unique.
 
- 
getUniqueJobParametersBuilder- Returns:
- a new JobParametersBuilder object containing only a parameter with a random
 number of type long, to ensure that the job instance will be unique.
 
- 
getStepRunnerConvenient method for subclasses to grab aStepRunnerfor running steps by name.- Returns:
- a StepRunner
 
- 
launchStepLaunch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME. A unique set of JobParameters will automatically be generated. An IllegalStateException is thrown if there is no Step with the given name.- Parameters:
- stepName- The name of the step to launch
- Returns:
- JobExecution
 
- 
launchStepLaunch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME. A unique set of JobParameters will automatically be generated. An IllegalStateException is thrown if there is no Step with the given name.- Parameters:
- stepName- The name of the step to launch
- jobExecutionContext- An ExecutionContext whose values will be loaded into the Job ExecutionContext prior to launching the step.
- Returns:
- JobExecution
 
- 
launchStepLaunch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME. An IllegalStateException is thrown if there is no Step with the given name.- Parameters:
- stepName- The name of the step to launch
- jobParameters- The JobParameters to use during the launch
- Returns:
- JobExecution
 
- 
launchSteppublic JobExecution launchStep(String stepName, JobParameters jobParameters, @Nullable ExecutionContext jobExecutionContext) Launch just the specified step in a surrounding single-step job of typeSimpleJobnamedStepRunner.JOB_NAME. An IllegalStateException is thrown if there is no Step with the given name.- Parameters:
- stepName- The name of the step to launch
- jobParameters- The JobParameters to use during the launch
- jobExecutionContext- An ExecutionContext whose values will be loaded into the Job ExecutionContext prior to launching the step.
- Returns:
- JobExecution
 
 
-