forked from aksdb/CalAnonSync
		
	Fixed endDate being wrong for wholeDay events (it actually should be +1)
This commit is contained in:
		
							parent
							
								
									88fe09795e
								
							
						
					
					
						commit
						10a3cc9637
					
				| @ -53,7 +53,7 @@ func (i ICal) UID() string { | |||||||
| // the event data of the ICal structure. Timezone information are ignored. | // the event data of the ICal structure. Timezone information are ignored. | ||||||
| // The time is therefore either a local time or a UTC time, depending on | // The time is therefore either a local time or a UTC time, depending on | ||||||
| // the notation. | // the notation. | ||||||
| func (i ICal) getTimeField(f string) (t time.Time, isDate bool) { | func (i ICal) getTimeField(f string) (t time.Time) { | ||||||
| 	for _, s := range i.eventData { | 	for _, s := range i.eventData { | ||||||
| 		if strings.HasPrefix(s, f) { | 		if strings.HasPrefix(s, f) { | ||||||
| 			st := s[strings.LastIndex(s, ":")+1:] | 			st := s[strings.LastIndex(s, ":")+1:] | ||||||
| @ -67,10 +67,8 @@ func (i ICal) getTimeField(f string) (t time.Time, isDate bool) { | |||||||
| 			var err error | 			var err error | ||||||
| 			if strings.Contains(s, ";VALUE=DATE") { | 			if strings.Contains(s, ";VALUE=DATE") { | ||||||
| 				t, err = time.ParseInLocation(ICAL_DATE, st, zone) | 				t, err = time.ParseInLocation(ICAL_DATE, st, zone) | ||||||
| 				isDate = true |  | ||||||
| 			} else { | 			} else { | ||||||
| 				t, err = time.ParseInLocation(ICAL_TIME, st, zone) | 				t, err = time.ParseInLocation(ICAL_TIME, st, zone) | ||||||
| 				isDate = false |  | ||||||
| 			} | 			} | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
| 				log.Printf("Cannot decode %s '%s': %s", f, st, err) | 				log.Printf("Cannot decode %s '%s': %s", f, st, err) | ||||||
| @ -78,7 +76,7 @@ func (i ICal) getTimeField(f string) (t time.Time, isDate bool) { | |||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	return time.Time{}, false | 	return | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| var fieldMatch = regexp.MustCompile(`^(\w+)[;:]`) | var fieldMatch = regexp.MustCompile(`^(\w+)[;:]`) | ||||||
| @ -104,12 +102,6 @@ func (ical *ICal) Update(newStart, newEnd time.Time, wholeDay bool) { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if wholeDay { |  | ||||||
| 		// For wholeDay events, the endDate is the beginning of the next day. For |  | ||||||
| 		// the formatting to work, we need to move that back into the previous day. |  | ||||||
| 		newEnd = newEnd.Add(-1 * time.Second) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	formatTime := func(t time.Time) string { | 	formatTime := func(t time.Time) string { | ||||||
| 		if wholeDay { | 		if wholeDay { | ||||||
| 			return ";VALUE=DATE:" + t.Format(ICAL_DATE) | 			return ";VALUE=DATE:" + t.Format(ICAL_DATE) | ||||||
| @ -140,20 +132,12 @@ func (ical *ICal) Update(newStart, newEnd time.Time, wholeDay bool) { | |||||||
| 
 | 
 | ||||||
| // Retrieve the start time of the event. | // Retrieve the start time of the event. | ||||||
| func (i ICal) Start() time.Time { | func (i ICal) Start() time.Time { | ||||||
| 	t, _ := i.getTimeField("DTSTART") | 	return i.getTimeField("DTSTART") | ||||||
| 	return t |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Retrieve the end time of the event. | // Retrieve the end time of the event. | ||||||
| func (i ICal) End() time.Time { | func (i ICal) End() time.Time { | ||||||
| 	t, isDate := i.getTimeField("DTEND") | 	return i.getTimeField("DTEND") | ||||||
| 	if isDate { |  | ||||||
| 		// If the end date is a date only, we need to move that to the |  | ||||||
| 		// 00:00 time one day ahead. |  | ||||||
| 		t = t.AddDate(0, 0, 1) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	return t |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (i *ICal) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { | func (i *ICal) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { | ||||||
|  | |||||||
| @ -81,7 +81,7 @@ func TestParseICal(t *testing.T) { | |||||||
| 		end := i.End() | 		end := i.End() | ||||||
| 
 | 
 | ||||||
| 		expectedStart := time.Date(2018, 4, 7, 0, 0, 0, 0, time.Local) | 		expectedStart := time.Date(2018, 4, 7, 0, 0, 0, 0, time.Local) | ||||||
| 		expectedEnd := time.Date(2018, 4, 10, 0, 0, 0, 0, time.Local) | 		expectedEnd := time.Date(2018, 4, 9, 0, 0, 0, 0, time.Local) | ||||||
| 
 | 
 | ||||||
| 		if !start.Equal(expectedStart) { | 		if !start.Equal(expectedStart) { | ||||||
| 			t.Errorf("Unexpected start time (%s != %s)", start, expectedStart) | 			t.Errorf("Unexpected start time (%s != %s)", start, expectedStart) | ||||||
| @ -107,8 +107,7 @@ func TestICal_Update(t *testing.T) { | |||||||
| 			t.Error("End not updated correctly") | 			t.Error("End not updated correctly") | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		stamp, _ := ical.getTimeField("DTSTAMP") | 		if ical.getTimeField("DTSTAMP").Sub(time.Now()) > 5*time.Second { | ||||||
| 		if stamp.Sub(time.Now()) > 5*time.Second { |  | ||||||
| 			t.Error("Timestamp doesn't seem to be updated") | 			t.Error("Timestamp doesn't seem to be updated") | ||||||
| 		} | 		} | ||||||
| 	}) | 	}) | ||||||
| @ -169,8 +168,7 @@ END:VCALENDAR` { | |||||||
| 			t.Error("End not updated correctly") | 			t.Error("End not updated correctly") | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		stamp, _ := ical.getTimeField("DTSTAMP") | 		if ical.getTimeField("DTSTAMP").Sub(time.Now()) > 5*time.Second { | ||||||
| 		if stamp.Sub(time.Now()) > 5*time.Second { |  | ||||||
| 			t.Error("Timestamp doesn't seem to be updated") | 			t.Error("Timestamp doesn't seem to be updated") | ||||||
| 		} | 		} | ||||||
| 	}) | 	}) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user