我们有一个服务类,负责根据用户输入调度作业。该类的一个方法接受具有用户输入的对象并为其构建cron表达式。 我开始为每个用例创建单元测试,并且在两个几乎完全相同的测试之间遇到了无法解释的差异:
每2天测试一次重复工作的情况:
"ChecklistCreationScheduler#buildCronExpression" should {
"build correct cron expressions for day interval of 2" in {
val jobScheduler = mock[JobScheduler]
val futureChecklistRepository = mock[FutureChecklistRepository]
val chlCreationScheduler = new ChecklistCreationScheduler(jobScheduler, futureChecklistRepository)
val now = DateTime.now.withSecondOfMinute(0).withMillisOfSecond(0)
val dayIntervalForm = mock[CreateJobForm]
dayIntervalForm.maybeDayInterval returns Some(2)
val cronStr = chlCreationScheduler.buildCronExpression(List(dayIntervalForm), now)
cronStr must_== "0 %s %s 1/2 * ? *".format(now.getMinuteOfHour, now.getHourOfDay)
val cronExpression = new CronExpression(cronStr)
val firstRun = cronExpression.getNextValidTimeAfter(now.minusMinutes(1).toDate)
firstRun must_== now.toDate
cronExpression.getNextValidTimeAfter(firstRun) must_== now.plusDays(2).toDate
}
}
每次都没有任何问题。
另外,用4天的间隔测试同样的事情:
"build correct cron expressions for day interval of 4" in {
val jobScheduler = mock[JobScheduler]
val futureChecklistRepository = mock[FutureChecklistRepository]
val chlCreationScheduler = new ChecklistCreationScheduler(jobScheduler, futureChecklistRepository)
val now = DateTime.now.withSecondOfMinute(0).withMillisOfSecond(0)
val dayIntervalForm = mock[CreateJobForm]
dayIntervalForm.maybeDayInterval returns Some(4)
val cronStr = chlCreationScheduler.buildCronExpression(List(dayIntervalForm), now)
cronStr must_== "0 %s %s 1/4 * ? *".format(now.getMinuteOfHour, now.getHourOfDay)
val cronExpression = new CronExpression(cronStr)
val firstRun = cronExpression.getNextValidTimeAfter(now.minusMinutes(1).toDate)
firstRun must_== now.toDate
cronExpression.getNextValidTimeAfter(firstRun) must_== now.plusDays(4).toDate
}
最后一个曾经在几天前工作,然后我开始得到同样的错误而没有真正改变任何东西。
' Wed Jul 13 05:57:00 UTC 2016'不等于' Mon Jul 11 05:57:00 UTC 2016'
此错误表示下一个计算日期不是第一个运行日期,而是之后的日期。为什么会这样?我错过了什么?
答案 0 :(得分:2)
您似乎对如何在cron表达式中解释1/4感到困惑。在日期字段中,它将匹配第1,5,9,13天等。所以,是的,如果"现在"是7月11日,下一场比赛将是7月13日。