/*
* Copyright 2001-2009 Terracotta, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy
* of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package org.eclipse.che.commons.schedule.executor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.testng.annotations.Test;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.text.ParseException;
import java.util.Calendar;
import java.util.Date;
import java.util.TimeZone;
import static org.testng.Assert.*;
public class CronExpressionTest {
private static final Logger LOG = LoggerFactory.getLogger(CronExpressionTest.class);
private static final String[] VERSIONS = new String[]{"1.5.2"};
private static final TimeZone EST_TIME_ZONE = TimeZone.getTimeZone("US/Eastern");
/**
* Get the object to serialize when generating serialized file for future
* tests, and against which to validate deserialized object.
*/
protected Object getTargetObject() throws ParseException {
CronExpression cronExpression = new CronExpression("0 15 10 * * ? 2005");
cronExpression.setTimeZone(EST_TIME_ZONE);
return cronExpression;
}
/**
* Get the Quartz versions for which we should verify
* serialization backwards compatibility.
*/
protected String[] getVersions() {
return VERSIONS;
}
/**
* Verify that the target object and the object we just deserialized
* match.
*/
protected void verifyMatch(Object target, Object deserialized) {
CronExpression targetCronExpression = (CronExpression)target;
CronExpression deserializedCronExpression = (CronExpression)deserialized;
assertNotNull(deserializedCronExpression);
assertEquals(targetCronExpression.getCronExpression(), deserializedCronExpression.getCronExpression());
assertEquals(targetCronExpression.getTimeZone(), deserializedCronExpression.getTimeZone());
}
/*
* Test method for 'org.quartz.CronExpression.isSatisfiedBy(Date)'.
*/
@Test
public void testIsSatisfiedBy() throws Exception {
CronExpression cronExpression = new CronExpression("0 15 10 * * ? 2005");
Calendar cal = Calendar.getInstance();
cal.set(2005, Calendar.JUNE, 1, 10, 15, 0);
assertTrue(cronExpression.isSatisfiedBy(cal.getTime()));
cal.set(Calendar.YEAR, 2006);
assertFalse(cronExpression.isSatisfiedBy(cal.getTime()));
cal = Calendar.getInstance();
cal.set(2005, Calendar.JUNE, 1, 10, 16, 0);
assertFalse(cronExpression.isSatisfiedBy(cal.getTime()));
cal = Calendar.getInstance();
cal.set(2005, Calendar.JUNE, 1, 10, 14, 0);
assertFalse(cronExpression.isSatisfiedBy(cal.getTime()));
}
@Test
public void testLastDayOffset() throws Exception {
CronExpression cronExpression = new CronExpression("0 15 10 L-2 * ? 2010");
Calendar cal = Calendar.getInstance();
cal.set(2010, Calendar.OCTOBER, 29, 10, 15, 0); // last day - 2
assertTrue(cronExpression.isSatisfiedBy(cal.getTime()));
cal.set(2010, Calendar.OCTOBER, 28, 10, 15, 0);
assertFalse(cronExpression.isSatisfiedBy(cal.getTime()));
cronExpression = new CronExpression("0 15 10 L-5W * ? 2010");
cal.set(2010, Calendar.OCTOBER, 26, 10, 15, 0); // last day - 5
assertTrue(cronExpression.isSatisfiedBy(cal.getTime()));
cronExpression = new CronExpression("0 15 10 L-1 * ? 2010");
cal.set(2010, Calendar.OCTOBER, 30, 10, 15, 0); // last day - 1
assertTrue(cronExpression.isSatisfiedBy(cal.getTime()));
cronExpression = new CronExpression("0 15 10 L-1W * ? 2010");
cal.set(2010, Calendar.OCTOBER, 29, 10, 15, 0); // nearest weekday to last day - 1 (29th is a friday in 2010)
assertTrue(cronExpression.isSatisfiedBy(cal.getTime()));
}
/*
* QUARTZ-571: Showing that expressions with months correctly serialize.
*/
@Test
public void testQuartz571() throws Exception {
CronExpression cronExpression = new CronExpression("19 15 10 4 Apr ? ");
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(baos);
oos.writeObject(cronExpression);
oos.flush();
ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
ObjectInputStream ois = new ObjectInputStream(bais);
CronExpression newExpression = (CronExpression)ois.readObject();
assertEquals(newExpression.getCronExpression(), cronExpression.getCronExpression());
// if broken, this will throw an exception
newExpression.getNextValidTimeAfter(new Date());
}
/**
* QTZ-259 : last day offset causes repeating fire time
*/
@Test
public void testQtz259() throws Exception {
CronExpression cronExpression = new CronExpression("0 0 0 L-2 * ? *");
int i = 0;
Date pdate = cronExpression.getNextValidTimeAfter(new Date());
while (++i < 26) {
Date date = cronExpression.getNextValidTimeAfter(pdate);
LOG.debug("fireTime: " + date + ", previousFireTime: " + pdate);
assertFalse(pdate.equals(date), "Next fire time is the same as previous fire time!");
pdate = date;
}
}
/**
* QTZ-259 : last day offset causes repeating fire time
*/
@Test
public void testQtz259LW() throws Exception {
CronExpression cronExpression = new CronExpression("0 0 0 LW * ? *");
int i = 0;
Date pdate = cronExpression.getNextValidTimeAfter(new Date());
while (++i < 26) {
Date date = cronExpression.getNextValidTimeAfter(pdate);
LOG.debug("fireTime: " + date + ", previousFireTime: " + pdate);
assertFalse(pdate.equals(date), "Next fire time is the same as previous fire time!");
pdate = date;
}
}
/*
* QUARTZ-574: Showing that storeExpressionVals correctly calculates the month number
*/
@Test
public void testQuartz574() {
try {
new CronExpression("* * * * Foo ? ");
fail("Expected ParseException did not fire for non-existent month");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("Invalid Month value:"), "Incorrect ParseException thrown");
}
try {
new CronExpression("* * * * Jan-Foo ? ");
fail("Expected ParseException did not fire for non-existent month");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("Invalid Month value:"), "Incorrect ParseException thrown");
}
}
@Test
public void testQuartz621() {
try {
new CronExpression("0 0 * * * *");
fail("Expected ParseException did not fire for wildcard day-of-month and day-of-week");
} catch (ParseException pe) {
assertTrue(
pe.getMessage()
.startsWith("Support for specifying both a day-of-week AND a day-of-month parameter is not implemented."),
"Incorrect ParseException thrown");
}
try {
new CronExpression("0 0 * 4 * *");
fail("Expected ParseException did not fire for specified day-of-month and wildcard day-of-week");
} catch (ParseException pe) {
assertTrue(
pe.getMessage()
.startsWith("Support for specifying both a day-of-week AND a day-of-month parameter is not implemented."),
"Incorrect ParseException thrown");
}
try {
new CronExpression("0 0 * * * 4");
fail("Expected ParseException did not fire for wildcard day-of-month and specified day-of-week");
} catch (ParseException pe) {
assertTrue(
pe.getMessage()
.startsWith("Support for specifying both a day-of-week AND a day-of-month parameter is not implemented."),
"Incorrect ParseException thrown");
}
}
@Test
public void testQuartz640() throws ParseException {
try {
new CronExpression("0 43 9 1,5,29,L * ?");
fail("Expected ParseException did not fire for L combined with other days of the month");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("Support for specifying 'L' and 'LW' with other days of the month is not implemented"),
"Incorrect ParseException thrown");
}
try {
new CronExpression("0 43 9 ? * SAT,SUN,L");
fail("Expected ParseException did not fire for L combined with other days of the week");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("Support for specifying 'L' with other days of the week is not implemented"),
"Incorrect ParseException thrown");
}
try {
new CronExpression("0 43 9 ? * 6,7,L");
fail("Expected ParseException did not fire for L combined with other days of the week");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("Support for specifying 'L' with other days of the week is not implemented"),
"Incorrect ParseException thrown");
}
try {
new CronExpression("0 43 9 ? * 5L");
} catch (ParseException pe) {
fail("Unexpected ParseException thrown for supported '5L' expression.");
}
}
@Test
public void testQtz96() throws ParseException {
try {
new CronExpression("0/5 * * 32W 1 ?");
fail("Expected ParseException did not fire for W with value larger than 31");
} catch (ParseException pe) {
assertTrue(
pe.getMessage().startsWith("The 'W' option does not make sense with values larger than"),
"Incorrect ParseException thrown");
}
}
@Test
public void testQtz395_CopyConstructorMustPreserveTimeZone() throws ParseException {
TimeZone nonDefault = TimeZone.getTimeZone("Europe/Brussels");
if (nonDefault.equals(TimeZone.getDefault())) {
nonDefault = EST_TIME_ZONE;
}
CronExpression cronExpression = new CronExpression("0 15 10 * * ? 2005");
cronExpression.setTimeZone(nonDefault);
CronExpression copyCronExpression = new CronExpression(cronExpression);
assertEquals(nonDefault, copyCronExpression.getTimeZone());
}
// // execute with version number to generate a new version's serialized form
// public static void main(String[] args) throws Exception {
// new CronExpressionTest().writeJobDataFile("1.5.2");
// }
}