Merge branch '57-bug-semester-ss-ws-check-wrong' into 'main'

Resolve "bug: semester ss/ws check wrong"

Closes #57

See merge request ekresse/htwkalender!46
This commit is contained in:
ekresse
2024-04-11 15:53:05 +00:00
3 changed files with 92 additions and 33 deletions

View File

@ -208,7 +208,7 @@ func getWeekEvents(start time.Time, end time.Time, cycle string) ([]time.Time, [
for _, day := range days { for _, day := range days {
weekDay, err := getDayInt(day) weekDay, err := getDayInt(day)
if err != nil { if err != nil {
slog.Error("Error while getting day int", err) slog.Error("Error while getting day int: "+day+" ", err)
} else { } else {
weekEvents = append(weekEvents, model.SportDayStartEnd{ weekEvents = append(weekEvents, model.SportDayStartEnd{
Start: time.Date(start.Year(), start.Month(), start.Day(), startHour, startMinute, 0, 0, start.Location()), Start: time.Date(start.Year(), start.Month(), start.Day(), startHour, startMinute, 0, 0, start.Location()),
@ -233,7 +233,7 @@ func getWeekEvents(start time.Time, end time.Time, cycle string) ([]time.Time, [
endI, endIErr = getDayInt(days[1]) endI, endIErr = getDayInt(days[1])
if endIErr != nil || startIErr != nil { if endIErr != nil || startIErr != nil {
slog.Error("Error while getting day int", startIErr, endIErr) slog.Error("Error while getting day int: "+days[0]+" - "+days[1]+" :", startIErr, endIErr)
} else { } else {
//create a int array with all days from start to end day //create a int array with all days from start to end day
var daysBetween []int var daysBetween []int
@ -258,7 +258,7 @@ func getWeekEvents(start time.Time, end time.Time, cycle string) ([]time.Time, [
dayInt, err := getDayInt(day) dayInt, err := getDayInt(day)
if err != nil { if err != nil {
slog.Error("Error while getting day int", err) slog.Error("Error while getting day int: "+day+" ", err)
} else { } else {
dayNumbers = append(dayNumbers, dayInt) dayNumbers = append(dayNumbers, dayInt)
} }
@ -270,7 +270,7 @@ func getWeekEvents(start time.Time, end time.Time, cycle string) ([]time.Time, [
weekDay, err := getDayInt(day) weekDay, err := getDayInt(day)
if err != nil { if err != nil {
slog.Error("Error while getting day int", err) slog.Error("Error while getting day int: "+day+" ", err)
} else { } else {
weekEvents = append(weekEvents, model.SportDayStartEnd{ weekEvents = append(weekEvents, model.SportDayStartEnd{
Start: time.Date(start.Year(), start.Month(), start.Day(), startHour, startMinute, 0, 0, start.Location()), Start: time.Date(start.Year(), start.Month(), start.Day(), startHour, startMinute, 0, 0, start.Location()),

View File

@ -69,48 +69,60 @@ 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",
} }
savedRecordsSs, errSs := fetchAndSaveAllEventsForSemester(app, time.March, time.October, "ss", clock, stubUrl) // Fetch and save events for all semesters
if errSs == nil { for _, semester := range calculateSemesterList(clock) {
savedRecords = append(savedRecords, savedRecordsSs...) events, fetchErr := fetchAndSaveAllEventsForSemester(app, semester, stubUrl)
} if fetchErr != nil {
savedRecordsWs, errWs := fetchAndSaveAllEventsForSemester(app, time.September, time.April, "ws", clock, stubUrl) return nil, fmt.Errorf("failed to fetch and save events for "+semester+": %w", err)
if errWs == nil { }
savedRecords = append(savedRecords, savedRecordsWs...) savedRecords = append(savedRecords, events...)
} }
return savedRecords, err return savedRecords, err
} }
func fetchAndSaveAllEventsForSemester( func fetchAndSaveAllEventsForSemester(
app *pocketbase.PocketBase, app *pocketbase.PocketBase,
before time.Month,
after time.Month,
semester string, semester string,
clock localTime.Clock,
stubUrl [2]string, stubUrl [2]string,
) ([]model.Event, error) { ) ([]model.Event, error) {
var err error = nil
var savedRecords []model.Event var savedRecords []model.Event
url := stubUrl[0] + semester + stubUrl[1]
if (clock.Now().Month() >= after) || (clock.Now().Month() <= before) { events, err := parseEventForOneSemester(url)
url := stubUrl[0] + semester + stubUrl[1] if err != nil {
var events []model.Event return nil, fmt.Errorf("failed to parse events for "+semester+": %w", err)
events, err = parseEventForOneSemester(url)
if err != nil {
return nil, fmt.Errorf("failed to parse events for "+semester+": %w", err)
}
err = db.DeleteAllEventsBySemesterWithoutCourse(app, "Sport", semester)
if err != nil {
return nil, fmt.Errorf("failed to delete all events for "+semester+": %w", err)
}
savedEvents, dbError := db.SaveEvents(events, app)
if dbError != nil {
return nil, fmt.Errorf("failed to save events for "+semester+": %w", dbError)
}
savedRecords = append(savedRecords, savedEvents...)
} }
err = db.DeleteAllEventsBySemesterWithoutCourse(app, "Sport", semester)
if err != nil {
return nil, fmt.Errorf("failed to delete all events for "+semester+": %w", err)
}
savedEvents, dbError := db.SaveEvents(events, app)
if dbError != nil {
return nil, fmt.Errorf("failed to save events for "+semester+": %w", dbError)
}
savedRecords = append(savedRecords, savedEvents...)
return savedRecords, err return savedRecords, err
} }
func calculateSemesterList(clock localTime.Clock) []string {
summerSemester := clock.Now().Month() >= time.March && clock.Now().Month() <= time.September
winterSemester := clock.Now().Month() <= time.March || clock.Now().Month() >= time.September
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) {
// Fetch Webpage from URL // Fetch Webpage from URL
webpage, err := fetch.GetHTML(url) webpage, err := fetch.GetHTML(url)
@ -128,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

@ -18,8 +18,10 @@ package v2
import ( import (
"htwkalender/model" "htwkalender/model"
mockTime "htwkalender/service/functions/time"
"reflect" "reflect"
"testing" "testing"
"time"
) )
func Test_switchNameAndNotesForExam(t *testing.T) { func Test_switchNameAndNotesForExam(t *testing.T) {
@ -97,3 +99,49 @@ func Test_switchNameAndNotesForExam(t *testing.T) {
}) })
} }
} }
func Test_calculateSemesterList(t *testing.T) {
type args struct {
clock mockTime.Clock
}
tests := []struct {
name string
args args
want []string
}{
{
name: "is summer semester",
args: args{
clock: mockTime.MockClock{
NowTime: time.Date(2024, 6, 1, 0, 0, 0, 0, time.UTC),
},
},
want: []string{"ss"},
},
{
name: "is winter semester",
args: args{
clock: mockTime.MockClock{
NowTime: time.Date(2024, 1, 1, 0, 0, 0, 0, time.UTC),
},
},
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 {
t.Run(tt.name, func(t *testing.T) {
if got := calculateSemesterList(tt.args.clock); !reflect.DeepEqual(got, tt.want) {
t.Errorf("calculateSemesterList() = %v, want %v", got, tt.want)
}
})
}
}