package calendar import ( "github.com/dolanor/caldav-go/caldav/entities" "github.com/dolanor/caldav-go/icalendar/components" "github.com/dolanor/caldav-go/icalendar/values" "testing" "time" ) func TestCalendar_GetEasterDay(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } easterDays := []time.Time{ time.Date(2019, time.April, 21, 0, 0, 0, 0, loc), time.Date(2020, time.April, 12, 0, 0, 0, 0, loc), time.Date(2021, time.April, 4, 0, 0, 0, 0, loc), } c := New(loc) for _, d := range easterDays { easter := c.GetEasterDay(d.Year()) if easter != d { t.Errorf("bad date for year %d, expected:%v ; actual:%v", d.Year(), d, easter) } } } func TestCalendar_GetHolidays(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } expectedHolidays := map[time.Time]bool{ time.Date(2020, time.January, 1, 0, 0, 0, 0, loc): true, time.Date(2020, time.April, 13, 0, 0, 0, 0, loc): true, time.Date(2020, time.May, 1, 0, 0, 0, 0, loc): true, time.Date(2020, time.May, 8, 0, 0, 0, 0, loc): true, time.Date(2020, time.May, 21, 0, 0, 0, 0, loc): true, time.Date(2020, time.July, 14, 0, 0, 0, 0, loc): true, time.Date(2020, time.August, 15, 0, 0, 0, 0, loc): true, time.Date(2020, time.November, 1, 0, 0, 0, 0, loc): true, time.Date(2020, time.November, 11, 0, 0, 0, 0, loc): true, time.Date(2020, time.December, 25, 0, 0, 0, 0, loc): true, } c := New(loc) holidays := c.GetHolidays(2020) if len(*holidays) != len(expectedHolidays) { t.Errorf("bad number of holidays, %d but %d are expected", len(*holidays), len(expectedHolidays)) } for _, h := range *holidays { if !expectedHolidays[h] { t.Errorf("%v is not a holiday", h) } } } func TestCalendar_GetHolidaysSet(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } expectedHolidays := []time.Time{ time.Date(2020, time.January, 1, 0, 0, 0, 0, loc), time.Date(2020, time.April, 13, 0, 0, 0, 0, loc), time.Date(2020, time.May, 1, 0, 0, 0, 0, loc), time.Date(2020, time.May, 8, 0, 0, 0, 0, loc), time.Date(2020, time.May, 21, 0, 0, 0, 0, loc), time.Date(2020, time.July, 14, 0, 0, 0, 0, loc), time.Date(2020, time.August, 15, 0, 0, 0, 0, loc), time.Date(2020, time.November, 1, 0, 0, 0, 0, loc), time.Date(2020, time.November, 11, 0, 0, 0, 0, loc), time.Date(2020, time.December, 25, 0, 0, 0, 0, loc), } c := New(loc) holidays := c.GetHolidaysSet(2020) if len(holidays) != len(expectedHolidays) { t.Errorf("bad number of holidays, %d but %d are expected", len(holidays), len(expectedHolidays)) } for _, h := range expectedHolidays { if !(holidays)[h] { t.Errorf("%v is not a holiday", h) } } } func TestCalendar_IsHolidays(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } expectedHolidays := []time.Time{ time.Date(2020, time.January, 1, 0, 0, 0, 0, loc), time.Date(2020, time.April, 13, 0, 0, 0, 0, loc), time.Date(2020, time.May, 1, 0, 0, 0, 0, loc), time.Date(2020, time.May, 8, 0, 0, 0, 0, loc), time.Date(2020, time.May, 21, 0, 0, 0, 0, loc), time.Date(2020, time.July, 14, 0, 0, 0, 0, loc), time.Date(2020, time.August, 15, 0, 0, 0, 0, loc), time.Date(2020, time.November, 1, 0, 0, 0, 0, loc), time.Date(2020, time.November, 11, 0, 0, 0, 0, loc), time.Date(2020, time.December, 25, 0, 0, 0, 0, loc), } c := New(loc) holidays := c.GetHolidaysSet(2020) if len(holidays) != len(expectedHolidays) { t.Errorf("bad number of holidays, %d but %d are expected", len(holidays), len(expectedHolidays)) } for _, h := range expectedHolidays { if !c.IsHoliday(h) { t.Errorf("%v is a holiday", h) } } if c.IsHoliday(time.Date(2019, time.January, 02, 0, 0, 0, 0, loc)) { t.Error("02 january should not be a holiday") } } func TestCalendar_IsWorkingDay(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } c := New(loc) if c.IsWorkingDay(time.Date(2019, time.January, 01, 0, 0, 0, 0, loc)) { t.Error("1st january is not a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 02, 0, 0, 0, 0, loc)) { t.Error("02 january should be a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 7, 0, 0, 0, 0, loc)) { t.Error("Monday should be a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 8, 0, 0, 0, 0, loc)) { t.Error("Tuesday should be a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 9, 0, 0, 0, 0, loc)) { t.Error("Wednesday should be a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 10, 0, 0, 0, 0, loc)) { t.Error("Thursday should be a working day") } if !c.IsWorkingDay(time.Date(2019, time.January, 11, 0, 0, 0, 0, loc)) { t.Error("Friday should be a working day") } if c.IsWorkingDay(time.Date(2019, time.January, 12, 0, 0, 0, 0, loc)) { t.Error("Saturday should not be a working day") } if c.IsWorkingDay(time.Date(2019, time.January, 13, 0, 0, 0, 0, loc)) { t.Error("Sunday should not be a working day") } } type MockCaldav struct { events []*components.Event } func (m *MockCaldav) QueryEvents(_ string, _ *entities.CalendarQuery) ([]*components.Event, error) { return m.events, nil } func TestCalendar_IsHolidaysFromCaldav(t *testing.T) { loc, err := time.LoadLocation("Europe/Paris") if err != nil { t.Errorf("unable to load time location: %v", err) t.Fail() } type fields struct { Location *time.Location cdav *MockCaldav caldavPath string caldavSummaryPattern string } type args struct { day time.Time } tests := []struct { name string fields fields args args want bool wantErr bool }{ { name: "Holidays in events", fields: fields{ Location: loc, cdav: &MockCaldav{ events: []*components.Event{ { UID: "1", DateStart: values.NewDateTime(time.Date(2022, time.April, 16, 0, 0, 0, 0, loc)), DateEnd: values.NewDateTime(time.Date(2022, time.April, 17, 0, 0, 0, 0, loc)), Summary: "Holidays", }, }, }, caldavPath: "my_calendar/", caldavSummaryPattern: "Holidays", }, args: args{ day: time.Date(2022, time.April, 16, 0, 0, 0, 0, loc), }, want: true, wantErr: false, }, { name: "Not Holidays in events", fields: fields{ Location: loc, cdav: &MockCaldav{ events: []*components.Event{ { UID: "1", DateStart: values.NewDateTime(time.Date(2022, time.April, 16, 0, 0, 0, 0, loc)), DateEnd: values.NewDateTime(time.Date(2022, time.April, 17, 0, 0, 0, 0, loc)), Summary: "Another event", }, }, }, caldavPath: "my_calendar/", caldavSummaryPattern: "Holidays", }, args: args{ day: time.Date(2022, time.April, 16, 0, 0, 0, 0, loc), }, want: false, wantErr: false, }, { name: "No events", fields: fields{ Location: loc, cdav: &MockCaldav{}, caldavPath: "my_calendar/", caldavSummaryPattern: "Holidays", }, args: args{ day: time.Date(2022, time.April, 15, 0, 0, 0, 0, loc), }, want: false, wantErr: false, }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { cal := New( loc, WithCaldav(tt.fields.cdav), WithCaldavPath(tt.fields.caldavPath), WithCaldavSummaryPattern(tt.fields.caldavSummaryPattern), ) got, err := cal.IsHolidaysFromCaldav(tt.args.day) if (err != nil) != tt.wantErr { t.Errorf("IsHolidaysFromCaldav() error = %v, wantErr %v", err, tt.wantErr) return } if got != tt.want { t.Errorf("IsHolidaysFromCaldav() got = %v, want %v", got, tt.want) } }) } }