This is our situation, and we usually specify a start time, eg - "23:00", an end time "24:00", and have a bit of logic somewhere to abort the run if the current time is outside that window. I finally noticed the bit of logic that does this, and realised that it was duplicated in every service has a *copy* of the same code. behold:
data:image/s3,"s3://crabby-images/1d3fd/1d3fd70ac6d4a2cf34ad4677a256a0bde9cc10fb" alt=""
Yuck.
Needless to say, I didn't like the duplication, or the code itself. I didn't have scope to retrofit the other services that used similar code, but I could fix this one and build a foundation for later.
First step was to refactor that mess out to a common util class, leaving us with this:
data:image/s3,"s3://crabby-images/bb081/bb0814c6c5a8f82be2b15caf76d35998ab37afd9" alt=""
...
and this:
data:image/s3,"s3://crabby-images/ee255/ee2552866fab5f72a17b8123557e5013d2a09191" alt=""
The first cut was just a raw refactor extract, the next step was to not use ugly Calendar code and handle the midnight cutover correctly (which is actually quite hard!). After a few false starts with Dates and dealing with GMT and daylight savings offsets, we ended up with this (convenience methods and javadoc not shown), which is unit-tested and guaranteed to work (except maybe during the daylight savings cutover itself..)
data:image/s3,"s3://crabby-images/32ccc/32ccc00716bb231ad7fff93ecf38a05e8e3225e8" alt=""
Much nicer, well we think so anyway.
If you can see a bug in there please let me know!!
No comments:
Post a Comment