We love challenges and invite you to test us. Our timescheduling functionality is extremely powerful due to the possibility of and / or connection, which is why we ask our customers and partners to challenge us from time to time.
John’s Challenge:
“I want a job that usually runs on the 5th of every month to run only if it’s a working day. If the 5th falls on a public holiday or on the weekend, the job should run one day earlier. If this is also a day off, the job should run on the first working day after the 5th of the month.”
And here is the solution:
First of all, we need a definition of the Swiss working days, which on the one hand defines the working days Monday to Friday and at the same time contains a list of all public holidays and excludes them with the status “Inverse”. In the case of list entries without a year, the holiday always falls on the same date, entries with a year are variable holidays that must be maintained annually. We have named this calendar “WORKDAYS_CH”:
data:image/s3,"s3://crabby-images/01840/018403dd70cda21728fec3a26e90dac960afc068" alt=""
Now two intervals are defined. The first interval contains the 4th and 5th of the month if these are working days:
data:image/s3,"s3://crabby-images/1324c/1324c2e0d1bb5c55252c064df69fad9012f7b7ac" alt=""
The second interval contains the 5th and a few subsequent days of the month, provided they are working days in Switzerland:
data:image/s3,"s3://crabby-images/6ead3/6ead340c2c2124b3e7470bb29ac93756722e7a5b" alt=""
In the next step, an interval JOHN_CHALLENGE_HLP is now defined, which supplies the last working day (if available) for the 4th and 5th and the first working day for the 5th and following
1. Dispatch Interval 5_OR_WORKDAY_BEFORE:
data:image/s3,"s3://crabby-images/ce3ef/ce3ef2cebb082a9336f32b3115820f3edfea1e8b" alt=""
2. Dispatch Interval 5_OR_WORKDAY_AFTER:
data:image/s3,"s3://crabby-images/7b207/7b2078907ce09734313ea32e55382542a6370414" alt=""
Now we pack the above interval into the JOHN_CHALLANGE interval and select the 1st day from these days
data:image/s3,"s3://crabby-images/2b644/2b644fc43d5cc423a85d35aa48f0bab4713d5f99" alt=""
Now we have an interval definition that we can use in job schedules. The following screenshot shows the use in a schedule with the executions for the next 400 days.
data:image/s3,"s3://crabby-images/993b1/993b19bb40bd7650cd437fbbb745a833040f25ee" alt=""
Do you also have a challenge for us? We look forward to tricky tasks. Feel free to contact us!