java 为什么quartz示例代码不能在Junit中测试?

fdbelqdn  于 2023-01-29  发布在  Java
关注(0)|答案(1)|浏览(155)

我正在运行这个quartz-2.1.0\examples\src\main\java\org\quartz\examples\example3示例代码,它运行得非常好,但是如果我把CronTriggerExample.java中的main代码移到一个junit测试类中,这个作业就不会运行了。下面是quartz示例代码(为了简化起见,我将其截断,您可以从quartz网站获得完整的代码)。

简单作业.java:

public class SimpleJob implements Job {
  private static Logger _log = LoggerFactory.getLogger(SimpleJob.class);

  public void execute(JobExecutionContext context) throws JobExecutionException {
    JobKey jobKey = context.getJobDetail().getKey();
    _log.info("SimpleJob says: " + jobKey + " executing at " + new Date());
  }
}

CronTrigger示例.java:

public class CronTriggerExample {
    public void run() throws Exception {
        Logger log = LoggerFactory.getLogger(CronTriggerExample.class);
        SchedulerFactory sf = new StdSchedulerFactory();
        Scheduler sched = sf.getScheduler();
        JobDetail job = newJob(SimpleJob.class)
            .withIdentity("job1", "group1")
            .build();
        CronTrigger trigger = newTrigger()
            .withIdentity("trigger1", "group1")
            .withSchedule(cronSchedule("0/3 * * * * ?"))
            .build();

        Date ft = sched.scheduleJob(job, trigger);
        log.info(job.getKey() + " has been scheduled to run at: " + ft
            + " and repeat based on expression: "
            + trigger.getCronExpression());

        sched.start();
    }

    public static void main(String[] args) throws Exception {
        CronTriggerExample example = new CronTriggerExample();
        example.run();
    }
}

如果我把main方法中的两行代码移到一个junit测试类(junit4)中,上面的代码运行良好,如下所示:

public class Test1 {
    @Test
    public void run() throws Exception {
        CronTriggerExample example = new CronTriggerExample();
        example.run();
    }
}

则作业不运行。
我很困惑为什么同样的代码不能在junit中运行?

yyhrrdl8

yyhrrdl81#

要自己查看问题,我建议在Eclipse这样的IDE中以调试模式运行这两段不同的代码。
当您在main中运行这两行时,即使main终止,您创建的Quartz Scheduler也会继续运行。
当您在JUnit中运行这两行代码时,JUnit框架会在所有单元测试终止时杀死所有剩余的线程。
要让Quartz的时间触发作业,您应该使用以下代码更改JUnit测试

public class Test1 {
    @Test
    public void run() throws Exception {
        CronTriggerExample example = new CronTriggerExample();
        example.run();

        Thread.sleep(240000); // Sleep 4 minutes (4*60*1.000 = 240.000)
    }
 }

相关问题