mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-07 18:25:23 +00:00
62934: Merged PLATFORM1 (Cloud33) to HEAD-BUG-FIX (Cloud33/4.3) 62832: ACE-403 Added tests for CronTriggerBean TODO: Add configured delayed test git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@62989 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
146 lines
4.1 KiB
Java
146 lines
4.1 KiB
Java
package org.alfresco.util;
|
|
|
|
import static org.junit.Assert.*;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import org.junit.After;
|
|
import org.junit.AfterClass;
|
|
import org.junit.Before;
|
|
import org.junit.BeforeClass;
|
|
import org.junit.Test;
|
|
import org.quartz.Job;
|
|
import org.quartz.JobDetail;
|
|
import org.quartz.JobExecutionContext;
|
|
import org.quartz.JobExecutionException;
|
|
import org.quartz.Scheduler;
|
|
import org.quartz.impl.StdSchedulerFactory;
|
|
import org.springframework.beans.BeansException;
|
|
import org.springframework.context.support.ClassPathXmlApplicationContext;
|
|
|
|
public class CronTriggerBeanTest {
|
|
|
|
private ClassPathXmlApplicationContext ctx;
|
|
private Scheduler scheduler;
|
|
private static ArrayList<Long> dummyJobRuns;
|
|
|
|
@BeforeClass
|
|
public static void setUpBeforeClass() throws Exception {
|
|
}
|
|
|
|
@AfterClass
|
|
public static void tearDownAfterClass() throws Exception {
|
|
}
|
|
|
|
@Before
|
|
public void setUp() throws Exception {
|
|
dummyJobRuns = new ArrayList<>();
|
|
this.ctx = null;
|
|
this.scheduler = null;
|
|
}
|
|
|
|
@After
|
|
public void tearDown() throws Exception {
|
|
try {
|
|
this.scheduler.shutdown();
|
|
} catch (Exception e) {
|
|
// do nothing
|
|
}
|
|
|
|
try {
|
|
ctx.close();
|
|
} catch (Exception e) {
|
|
// do nothing
|
|
}
|
|
}
|
|
|
|
@Test
|
|
public void testCodedCronTriggerBean() throws Exception {
|
|
assertEquals(0, dummyJobRuns.size());
|
|
scheduler = StdSchedulerFactory.getDefaultScheduler();
|
|
scheduler.start();
|
|
CronTriggerBean ctBean = new CronTriggerBean();
|
|
ctBean.setBeanName("Dummy");
|
|
ctBean.setCronExpression("0/1 * * * * ? *");
|
|
ctBean.setEnabled(true);
|
|
JobDetail jobDetail = new JobDetail("DummyJob", "DefaultGroup", DummyJob.class);
|
|
ctBean.setJobDetail(jobDetail);
|
|
ctBean.setScheduler(scheduler);
|
|
ctBean.afterPropertiesSet();
|
|
|
|
Thread.sleep(1000);
|
|
int runs = dummyJobRuns.size();
|
|
assertTrue(runs > 0);
|
|
|
|
scheduler.shutdown();
|
|
Thread.sleep(1000);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
Thread.sleep(1000);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
}
|
|
|
|
@Test
|
|
public void testCodedDelayedCronTriggerBean() throws Exception {
|
|
assertEquals(0, dummyJobRuns.size());
|
|
Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
|
|
scheduler.start();
|
|
CronTriggerBean ctBean = new CronTriggerBean();
|
|
ctBean.setBeanName("Dummy");
|
|
ctBean.setCronExpression("0/1 * * * * ? *");
|
|
ctBean.setEnabled(true);
|
|
JobDetail jobDetail = new JobDetail("DummyJob", "DefaultGroup", DummyJob.class);
|
|
ctBean.setJobDetail(jobDetail);
|
|
ctBean.setScheduler(scheduler);
|
|
final long START_DELAY = 4000L;
|
|
ctBean.setStartDelay(START_DELAY);
|
|
ctBean.afterPropertiesSet();
|
|
|
|
// It should not have run during the delay. Give a second precision leeway
|
|
Thread.sleep(START_DELAY - 1000);
|
|
assertEquals(0, dummyJobRuns.size());
|
|
// It should have had a chance to run after the delay
|
|
Thread.sleep(1000);
|
|
int runs = dummyJobRuns.size();
|
|
assertTrue(runs > 0);
|
|
// It should not have run again after shutdown
|
|
scheduler.shutdown();
|
|
Thread.sleep(1000);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
// Indeed after another second, it should not have changed.
|
|
Thread.sleep(1000);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
}
|
|
|
|
@Test
|
|
public void testConfiguredCronTriggerBean() throws BeansException,
|
|
Exception {
|
|
assertEquals(0, dummyJobRuns.size());
|
|
ctx = new ClassPathXmlApplicationContext(
|
|
"alfresco/scheduler-core-context.xml",
|
|
"org/alfresco/util/test-scheduled-jobs-context.xml");
|
|
CronTriggerBean ctBean = ctx.getBean(CronTriggerBean.class);
|
|
scheduler = ctBean.getScheduler();
|
|
scheduler.start();
|
|
|
|
// After the interval, there should be at least one run
|
|
final long INTERVAL = 2000L;
|
|
Thread.sleep(INTERVAL);
|
|
int runs = dummyJobRuns.size();
|
|
assertTrue(runs > 0);
|
|
|
|
// When the context closes, the scheduler should close, thereby stopping the job
|
|
ctx.close();
|
|
Thread.sleep(INTERVAL);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
Thread.sleep(INTERVAL);
|
|
assertEquals(runs, dummyJobRuns.size());
|
|
}
|
|
|
|
public static class DummyJob implements Job {
|
|
public void execute(JobExecutionContext context) throws JobExecutionException {
|
|
long now = System.currentTimeMillis();
|
|
dummyJobRuns.add(now);
|
|
}
|
|
}
|
|
}
|