feat:#57 updated function and calc

This commit is contained in:
Elmar Kresse
2024-04-11 17:23:04 +02:00
parent 2f0fa03b58
commit 12ad568088
2 changed files with 40 additions and 23 deletions

View File

@@ -69,17 +69,15 @@ func FetchAllEventsAndSave(app *pocketbase.PocketBase, clock localTime.Clock) ([
"%0A?&template=sws_modul&weeks=1-65&combined=yes", "%0A?&template=sws_modul&weeks=1-65&combined=yes",
} }
if isSummerSemester(clock) { // Fetch and save events for all semesters
savedRecordsSs, errSs := fetchAndSaveAllEventsForSemester(app, "ss", stubUrl) for _, semester := range calculateSemesterList(clock) {
if errSs == nil { events, fetchErr := fetchAndSaveAllEventsForSemester(app, semester, stubUrl)
savedRecords = append(savedRecords, savedRecordsSs...) if fetchErr != nil {
} return nil, fmt.Errorf("failed to fetch and save events for "+semester+": %w", err)
} else {
savedRecordsWs, errWs := fetchAndSaveAllEventsForSemester(app, "ws", stubUrl)
if errWs == nil {
savedRecords = append(savedRecords, savedRecordsWs...)
} }
savedRecords = append(savedRecords, events...)
} }
return savedRecords, err return savedRecords, err
} }
@@ -106,12 +104,23 @@ func fetchAndSaveAllEventsForSemester(
return savedRecords, err return savedRecords, err
} }
func isSummerSemester(clock localTime.Clock) bool { func calculateSemesterList(clock localTime.Clock) []string {
if clock.Now().Month() >= time.April && clock.Now().Month() <= time.September { summerSemester := clock.Now().Month() >= time.March && clock.Now().Month() <= time.September
return true winterSemester := clock.Now().Month() <= time.March || clock.Now().Month() >= time.September
} else {
return false if summerSemester && winterSemester {
return []string{"ss", "ws"}
} }
if summerSemester {
return []string{"ss"}
}
if winterSemester {
return []string{"ws"}
}
return []string{"ss", "ws"}
} }
func parseEventForOneSemester(url string) ([]model.Event, error) { func parseEventForOneSemester(url string) ([]model.Event, error) {
@@ -131,7 +140,6 @@ func parseEventForOneSemester(url string) ([]model.Event, error) {
// Get all event tables and all day labels // Get all event tables and all day labels
eventTables := getEventTables(doc) eventTables := getEventTables(doc)
allDayLabels := getAllDayLabels(doc) allDayLabels := getAllDayLabels(doc)
eventsWithCombinedWeeks := toEvents(eventTables, allDayLabels) eventsWithCombinedWeeks := toEvents(eventTables, allDayLabels)
splitEventsByWeekVal := splitEventsByWeek(eventsWithCombinedWeeks) splitEventsByWeekVal := splitEventsByWeek(eventsWithCombinedWeeks)

View File

@@ -100,14 +100,14 @@ func Test_switchNameAndNotesForExam(t *testing.T) {
} }
} }
func Test_isSummerSemester(t *testing.T) { func Test_calculateSemesterList(t *testing.T) {
type args struct { type args struct {
clock mockTime.MockClock clock mockTime.Clock
} }
tests := []struct { tests := []struct {
name string name string
args args args args
want bool want []string
}{ }{
{ {
name: "is summer semester", name: "is summer semester",
@@ -116,22 +116,31 @@ func Test_isSummerSemester(t *testing.T) {
NowTime: time.Date(2024, 6, 1, 0, 0, 0, 0, time.UTC), NowTime: time.Date(2024, 6, 1, 0, 0, 0, 0, time.UTC),
}, },
}, },
want: true, want: []string{"ss"},
}, },
{ {
name: "is not summer semester", name: "is winter semester",
args: args{ args: args{
clock: mockTime.MockClock{ clock: mockTime.MockClock{
NowTime: time.Date(2024, 1, 1, 0, 0, 0, 0, time.UTC), NowTime: time.Date(2024, 1, 1, 0, 0, 0, 0, time.UTC),
}, },
}, },
want: false, want: []string{"ws"},
},
{
name: "is in both",
args: args{
clock: mockTime.MockClock{
NowTime: time.Date(2024, 3, 22, 0, 0, 0, 0, time.UTC),
},
},
want: []string{"ss", "ws"},
}, },
} }
for _, tt := range tests { for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) { t.Run(tt.name, func(t *testing.T) {
if got := isSummerSemester(tt.args.clock); got != tt.want { if got := calculateSemesterList(tt.args.clock); !reflect.DeepEqual(got, tt.want) {
t.Errorf("isSummerSemester() = %v, want %v", got, tt.want) t.Errorf("calculateSemesterList() = %v, want %v", got, tt.want)
} }
}) })
} }