diff --git a/src/main/java/org/pkwmtt/timetable/TimetableCacheService.java b/src/main/java/org/pkwmtt/timetable/TimetableCacheService.java index c36307d..449e7ea 100644 --- a/src/main/java/org/pkwmtt/timetable/TimetableCacheService.java +++ b/src/main/java/org/pkwmtt/timetable/TimetableCacheService.java @@ -73,7 +73,10 @@ public TimetableDTO getGeneralGroupSchedule (String generalGroupName) public Map getGeneralGroupsMap () throws WebPageContentNotAvailableException { var url = mainUrl + "lista.html"; var html = fetchData(url); - String json = cache.get("generalGroupMap", () -> mapper.writeValueAsString(parser.parseGeneralGroups(html))); + String json = cache.get( + "generalGroupMap", + () -> mapper.writeValueAsString(parser.parseGeneralGroups(html)) + ); return getMappedValue( json, "generalGroupList", cache, new TypeReference<>() { @@ -88,6 +91,30 @@ public Map getGeneralGroupsMap () throws WebPageContentNotAvaila * @throws WebPageContentNotAvailableException if hour definition page can't be loaded */ public List getListOfHours () throws WebPageContentNotAvailableException { + + //Hard coded values for hours, caused by inconsistent timetable hours range + return List.of( + "7:30-8:15", + "8:15-9:00", + "9:15-10:00", + "10:00-10:45", + "11:00-11:45", + "11:45-12:30", + "12:45-13:30", + "13:30-14:15", + "14:30-15:15", + "15:15-16:00", + "16:15-17:00", + "17:00-17:45", + "18:00-18:45", + "18:45-19:30", + "19:45-20:30", + "20:30-21:15" + ); + } + + @SuppressWarnings("unused") + private List fetchListOfHours () { String url = mainUrl + "plany/o25.html"; String json = cache.get("hourList", () -> mapper.writeValueAsString(parser.parseHours(fetchData(url)))); @@ -97,9 +124,8 @@ public List getListOfHours () throws WebPageContentNotAvailableException ); //Delete useless spaces - result = result.stream().map(item -> item.replaceAll(" ", "")).toList(); + return result.stream().map(item -> item.replaceAll(" ", "")).toList(); - return result; } /** diff --git a/src/test/java/org/pkwmtt/cache/CacheConfigTest.java b/src/test/java/org/pkwmtt/cache/CacheConfigTest.java index 53e9c30..b983b42 100644 --- a/src/test/java/org/pkwmtt/cache/CacheConfigTest.java +++ b/src/test/java/org/pkwmtt/cache/CacheConfigTest.java @@ -1,6 +1,7 @@ package org.pkwmtt.cache; import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.pkwmtt.ValuesForTest; import org.pkwmtt.timetable.TimetableCacheService; @@ -62,6 +63,7 @@ void testCacheKeyPresent_Schedule () { } @Test + @Disabled("hard coded hours") void testCacheKeyPresent_HoursList () { //given diff --git a/src/test/java/org/pkwmtt/timetable/TimetableCacheServiceTest.java b/src/test/java/org/pkwmtt/timetable/TimetableCacheServiceTest.java index bef3add..c4c80a3 100644 --- a/src/test/java/org/pkwmtt/timetable/TimetableCacheServiceTest.java +++ b/src/test/java/org/pkwmtt/timetable/TimetableCacheServiceTest.java @@ -2,6 +2,7 @@ import lombok.extern.slf4j.Slf4j; import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; import org.junit.jupiter.api.Test; import org.pkwmtt.ValuesForTest; import org.pkwmtt.cache.CacheInspector; @@ -39,6 +40,7 @@ public void initWireMock () { } @Test + @Disabled("hard coded values") public void shouldHourListBePresentInCache () { //given var key = "hourList";