-
Notifications
You must be signed in to change notification settings - Fork 214
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[incubator-kie-issues#1648] Fix BusinessCalendarImpl time calculation when currentCalHour < startHour #3795
[incubator-kie-issues#1648] Fix BusinessCalendarImpl time calculation when currentCalHour < startHour #3795
Conversation
… when currentCalHour < startHour
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@martinweiler code looks good to me, especially big kudos for the tests. I have one comment inline.
@@ -293,7 +299,9 @@ public Date calculateBusinessTimeAsDate(String timeExpression) { | |||
c.set(Calendar.HOUR_OF_DAY, startHour); | |||
c.add(Calendar.HOUR_OF_DAY, currentCalHour - endHour); | |||
} else if (currentCalHour < startHour) { | |||
c.add(Calendar.HOUR_OF_DAY, startHour); | |||
c.add(Calendar.HOUR_OF_DAY, startHour - currentCalHour); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As we change construction of HOUR_OF_DAY
, maybe it would be worth to add also *hour*
tests?
During my brief check, I didn't find such tests. Also, I didn't check if tring duration = "2h";
is a correct duration value. I wrote the code below just in github comment.
If you think, such tests are not needed, feel free to proceed without adding such tests.
@Test
public void testCalculateHoursBeforeStartHour() {
Properties config = new Properties();
config.setProperty(BusinessCalendarImpl.HOURS_PER_DAY, "4");
config.setProperty(BusinessCalendarImpl.START_HOUR, "14");
config.setProperty(BusinessCalendarImpl.END_HOUR, "18");
String currentDate = "2024-11-28 10:48:33.000";
String duration = "2h";
String expectedDate = "2024-11-28 16:00:00";
SessionPseudoClock clock = new StaticPseudoClock(parseToDateWithTimeAndMillis(currentDate).getTime());
BusinessCalendarImpl businessCal = new BusinessCalendarImpl(config, clock);
Date result = businessCal.calculateBusinessTimeAsDate(duration);
assertThat(formatDate("yyyy-MM-dd HH:mm:ss", result)).isEqualTo(expectedDate);
}
@Test
public void testCalculateHoursBeforeEndHour() {
Properties config = new Properties();
config.setProperty(BusinessCalendarImpl.HOURS_PER_DAY, "4");
config.setProperty(BusinessCalendarImpl.START_HOUR, "14");
config.setProperty(BusinessCalendarImpl.END_HOUR, "18");
String currentDate = "2024-11-28 17:58:33.000";
String duration = "2h";
String expectedDate = "2024-11-29 15:58:33";
SessionPseudoClock clock = new StaticPseudoClock(parseToDateWithTimeAndMillis(currentDate).getTime());
BusinessCalendarImpl businessCal = new BusinessCalendarImpl(config, clock);
Date result = businessCal.calculateBusinessTimeAsDate(duration);
assertThat(formatDate("yyyy-MM-dd HH:mm:ss", result)).isEqualTo(expectedDate);
}
FYI @Abhitocode @gitgabrio this could create a conflict with the refactoring you're doing |
@martinweiler |
@gitgabrio hi, not sure if your point is:
Sorry, just want to be sure what I should do. Thank you for clarification. |
@jomarko |
… when currentCalHour < startHour (apache#3795) * [incubator-kie-issues#1648] Fix BusinessCalendarImpl time calculation when currentCalHour < startHour * Test case for BusinessCalendar time calculation when currentCalHour < endHour * Use parseToDateWithTimeAndMillis to make sure calculation is exact * Additional tests to verify correct handling of seconds
Closes: apache/incubator-kie-issues#1648