Search in sources :

Example 1 with JobExplorer

use of org.springframework.batch.core.explore.JobExplorer in project head by mifos.

the class MifosScheduler method getJobsPreviousRunTime.

public Date getJobsPreviousRunTime(String jobName) {
    JobExplorer explorer = getBatchJobExplorer();
    List<JobInstance> jobInstances = explorer.getJobInstances(jobName, 0, 1);
    if (jobInstances.size() == 0) {
        return new Date(0);
    }
    JobInstance jobInstance = jobInstances.get(0);
    long executionTimeInMillis = jobInstance.getJobParameters().getLong(MifosBatchJob.JOB_EXECUTION_TIME_KEY);
    return new Date(executionTimeInMillis);
}
Also used : JobInstance(org.springframework.batch.core.JobInstance) JobExplorer(org.springframework.batch.core.explore.JobExplorer) Date(java.util.Date)

Example 2 with JobExplorer

use of org.springframework.batch.core.explore.JobExplorer in project head by mifos.

the class MifosScheduler method getJobFailDescription.

public String getJobFailDescription(String jobName) {
    String failDescription = null;
    JobExplorer explorer = getBatchJobExplorer();
    List<JobInstance> jobInstances = explorer.getJobInstances(jobName, 0, 1);
    if (jobInstances.size() > 0) {
        List<JobExecution> jobExecutions = explorer.getJobExecutions(jobInstances.get(0));
        if (jobExecutions.size() > 0) {
            Collection<StepExecution> steps = jobExecutions.get(0).getStepExecutions();
            if (steps.size() > 0) {
                StepExecution step = steps.iterator().next();
                if (!step.getExitStatus().getExitDescription().isEmpty()) {
                    failDescription = step.getExitStatus().getExitDescription();
                }
            }
        }
    }
    return failDescription;
}
Also used : JobExecution(org.springframework.batch.core.JobExecution) JobInstance(org.springframework.batch.core.JobInstance) JobExplorer(org.springframework.batch.core.explore.JobExplorer) StepExecution(org.springframework.batch.core.StepExecution)

Example 3 with JobExplorer

use of org.springframework.batch.core.explore.JobExplorer in project head by mifos.

the class MifosScheduler method getJobsLastSuccessfulRunTime.

public Date getJobsLastSuccessfulRunTime(String jobName) {
    JobExplorer explorer = getBatchJobExplorer();
    List<JobInstance> jobInstances = explorer.getJobInstances(jobName, 0, 100);
    for (JobInstance job : jobInstances) {
        for (JobExecution execution : explorer.getJobExecutions(job)) {
            if (BatchStatus.COMPLETED.equals(execution.getStatus())) {
                long executionTimeInMillis = job.getJobParameters().getLong(MifosBatchJob.JOB_EXECUTION_TIME_KEY);
                return new Date(executionTimeInMillis);
            }
        }
    }
    return new Date(0);
}
Also used : JobExecution(org.springframework.batch.core.JobExecution) JobInstance(org.springframework.batch.core.JobInstance) JobExplorer(org.springframework.batch.core.explore.JobExplorer) Date(java.util.Date)

Example 4 with JobExplorer

use of org.springframework.batch.core.explore.JobExplorer in project head by mifos.

the class BatchJobCatchUpIntegrationTest method testIncompleteTaskDelay.

@Test
public void testIncompleteTaskDelay() throws Exception {
    mifosScheduler = getMifosScheduler("org/mifos/framework/components/batchjobs/catchUpTask.xml");
    Scheduler scheduler = mifosScheduler.getScheduler();
    ProductStatus productStatusTask = new ProductStatus();
    productStatusTask.setJobExplorer(mifosScheduler.getBatchJobExplorer());
    productStatusTask.setJobLauncher(mifosScheduler.getBatchJobLauncher());
    productStatusTask.setJobLocator(mifosScheduler.getBatchJobLocator());
    productStatusTask.setJobRepository(mifosScheduler.getBatchJobRepository());
    String quartzJobName = "ProductStatusJob";
    String quartzTriggerName = "ProductStatusTrigger2";
    Calendar calendar = Calendar.getInstance();
    calendar.set(Calendar.MILLISECOND, 0);
    calendar.set(Calendar.SECOND, 10);
    Date previousFireTime = calendar.getTime();
    calendar.set(Calendar.SECOND, 21);
    Date quartzFireTime = calendar.getTime();
    calendar.set(Calendar.SECOND, 22);
    Date quartzNextFireTime = calendar.getTime();
    calendar.set(Calendar.SECOND, 20);
    Date quartzPrevFireTime = calendar.getTime();
    JobDetail jobDetail = scheduler.getJobDetail(quartzJobName, Scheduler.DEFAULT_GROUP);
    jobDetail.setJobDataMap(new JobDataMap());
    CronTrigger trigger = new CronTrigger(quartzTriggerName, Scheduler.DEFAULT_GROUP, quartzJobName, Scheduler.DEFAULT_GROUP, "* * * * * ?");
    trigger.setJobDataMap(new JobDataMap());
    TriggerFiredBundle triggerFiredBundle = new TriggerFiredBundle(jobDetail, trigger, new BaseCalendar(), false, quartzFireTime, quartzFireTime, quartzPrevFireTime, quartzNextFireTime);
    JobExecutionContext jobExecutionContext = new JobExecutionContext(scheduler, triggerFiredBundle, productStatusTask);
    JobLauncher jobLauncher = mifosScheduler.getBatchJobLauncher();
    JobLocator jobLocator = mifosScheduler.getBatchJobLocator();
    jobLauncher.run(jobLocator.getJob(jobName), MifosBatchJob.createJobParameters(previousFireTime.getTime()));
    Thread.sleep(1500);
    productStatusTask.catchUpMissedLaunches(jobLocator.getJob(jobName), jobExecutionContext);
    JobExplorer explorer = mifosScheduler.getBatchJobExplorer();
    List<JobInstance> jobInstances = explorer.getJobInstances(jobName, 0, 20);
    Assert.assertEquals(11, jobInstances.size());
    for (JobInstance jobInstance : jobInstances) {
        List<JobExecution> jobExecutions = explorer.getJobExecutions(jobInstance);
        Assert.assertEquals(BatchStatus.COMPLETED, jobExecutions.get(0).getStatus());
        Assert.assertEquals(calendar.getTimeInMillis(), jobInstance.getJobParameters().getLong(MifosBatchJob.JOB_EXECUTION_TIME_KEY));
        calendar.roll(Calendar.SECOND, false);
    }
}
Also used : JobDataMap(org.quartz.JobDataMap) CronTrigger(org.quartz.CronTrigger) JobLauncher(org.springframework.batch.core.launch.JobLauncher) BaseCalendar(org.quartz.impl.calendar.BaseCalendar) JobInstance(org.springframework.batch.core.JobInstance) Scheduler(org.quartz.Scheduler) Calendar(java.util.Calendar) BaseCalendar(org.quartz.impl.calendar.BaseCalendar) JobLocator(org.springframework.batch.core.configuration.JobLocator) ProductStatus(org.mifos.framework.components.batchjobs.helpers.ProductStatus) TriggerFiredBundle(org.quartz.spi.TriggerFiredBundle) Date(java.util.Date) JobExecution(org.springframework.batch.core.JobExecution) JobDetail(org.quartz.JobDetail) JobExecutionContext(org.quartz.JobExecutionContext) JobExplorer(org.springframework.batch.core.explore.JobExplorer) Test(org.junit.Test)

Example 5 with JobExplorer

use of org.springframework.batch.core.explore.JobExplorer in project head by mifos.

the class TaskRunningIntegrationTest method testRunningAllTasks.

@Test
@Ignore
public void testRunningAllTasks() throws Exception {
    mifosScheduler = getMifosScheduler("org/mifos/framework/components/batchjobs/taskRunningTestTask.xml");
    mifosScheduler.runAllTasks();
    Thread.sleep(5000);
    JobExplorer explorer = mifosScheduler.getBatchJobExplorer();
    List<String> executedJobs = explorer.getJobNames();
    Assert.assertEquals(8, executedJobs.size());
    List<String> jobNames = mifosScheduler.getTaskNames();
    for (String jobName : jobNames) {
        Assert.assertTrue(executedJobs.contains(jobName));
    }
}
Also used : JobExplorer(org.springframework.batch.core.explore.JobExplorer) Ignore(org.junit.Ignore) Test(org.junit.Test)

Aggregations

JobExplorer (org.springframework.batch.core.explore.JobExplorer)16 Test (org.junit.Test)12 JobInstance (org.springframework.batch.core.JobInstance)12 JobExecution (org.springframework.batch.core.JobExecution)11 Date (java.util.Date)5 Ignore (org.junit.Ignore)3 StepExecution (org.springframework.batch.core.StepExecution)3 JobLocator (org.springframework.batch.core.configuration.JobLocator)3 JobLauncher (org.springframework.batch.core.launch.JobLauncher)3 AnnotationConfigApplicationContext (org.springframework.context.annotation.AnnotationConfigApplicationContext)2 Calendar (java.util.Calendar)1 ProductStatus (org.mifos.framework.components.batchjobs.helpers.ProductStatus)1 CronTrigger (org.quartz.CronTrigger)1 JobDataMap (org.quartz.JobDataMap)1 JobDetail (org.quartz.JobDetail)1 JobExecutionContext (org.quartz.JobExecutionContext)1 Scheduler (org.quartz.Scheduler)1 BaseCalendar (org.quartz.impl.calendar.BaseCalendar)1 TriggerFiredBundle (org.quartz.spi.TriggerFiredBundle)1 JobParameters (org.springframework.batch.core.JobParameters)1