mirror of
https://gitlab.dit.htwk-leipzig.de/htwk-software/htwkalender-pwa.git
synced 2025-08-07 04:09:17 +02:00
feat:#57 updated function and calc
This commit is contained in:
@@ -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)
|
||||||
|
@@ -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)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user