2016-06-25 14 views
6

Ho eseguito alcuni test. Ecco il mio codice:La libreria DDay Ical calcola correttamente le regole ricorrenti?

var systemTimeZone = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 
var icalTimeZone = iCalTimeZone.FromSystemTimeZone(systemTimeZone); 

var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 

var iCalendar = new iCalendar(); 
var pacificTimeZone = _iCalendar.AddTimeZone(icalTimeZone); 

var event = new Event 
{ 
    Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
    DTStart = new iCalDateTime(2015, 9, 8, 10, 30, 0, pacificTimeZone.TZID, iCalendar), 
    Duration = new TimeSpan(0, 1, 0, 0) 
}; 

var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 

event.RecurrenceRules.Add(rp); 
iCalendar.Events.Add(_event); 
var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 

Ecco il risultato:

10 occorrenze - qui ci sono le ricorrenze proprietà Period.StartTime.Value e UTC

Valore - 9/8/2015 10:30:00 - UTC 9/8/2015 17:30:00
Valore - 15/09/2015 10:30:00 - UTC 9/15/2015 17:30:00
Valore - 2015/09/22 10:30:00 - UTC 9/22/2015 17:30:00
Valore-9/29/2015 10:30:00 - UTC 9/29/2015 17:30:00
Valore - 2015/10/06 10:30:00 - UTC 2015/10/06 17: 30:00
Valore - 10/13/2015 10:30:00 - UTC 13/10/2015 1 7:30:00
Valore - 2015/10/20 10:30:00 - UTC 10/20/2015 17:30:00
Valore - 2015/10/27 10:30: 00 - UTC 10/27/2015 17:30:00
Valore -11/3/2015 10:30:00 - UTC 2015/11/03 17:30:00 (questo dovrebbe essere 18:30:00!)
Valore - 11/10/2015 10:30:00 - UTC 2015/11/10 17:30:00 (questo dovrebbe essere 18:30:00!)

enter image description here

Come si può vedere, gli ultimi due dovrebbero avere un tempo di 18:30 UTC : 00. Quindi mi chiedo se questo è il modo in cui funziona DDay Ical e non dovrei contare sul fatto che ottenga il datetime UTC giusto o se sto facendo qualcosa di sbagliato.

+0

potrebbe avere qualcosa a che fare con l'ora legale? – Thorarins

risposta

8

Si ottiene questa differenza di orario a causa dell'ora legale.Una soluzione possibile, non è quello di ottenere il fuso orario in base al nome Pacific Standard Time

// First load a file containing time zone information for Pacific Standard Time 
var systemTimeZone = TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 

Al posto di questo fuso orario del sistema uso come

var systemTimeZone = TimeZoneInfo.GetSystemTimeZones().FirstOrDefault(); 

O semplicemente aggiungere il fuso orario locale:

iCalendar iCalendar= new iCalendar(); 
iCalendar.AddLocalTimeZone(); 

Per trovare tutti i fusi orari registrati, click here

ReadOnlyCollection<TimeZoneInfo> zones = TimeZoneInfo.GetSystemTimeZones(); 
Console.WriteLine("The local system has the following {0} time zones", zones.Count); 
foreach (TimeZoneInfo zone in zones) 
    Console.WriteLine(zone.Id); 

ho semplicemente utilizzare GetSystemTimeZones() nel mio codice come

public static void Test1() 
    { 
     var systemTimeZone = TimeZoneInfo.GetSystemTimeZones().FirstOrDefault(); 
     //TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time"); 
     var icalTimeZone = iCalTimeZone.FromSystemTimeZone(systemTimeZone); 

     var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
     var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 

     var iCalendar = new iCalendar(); 
     var pacificTimeZone = iCalendar.AddTimeZone(icalTimeZone); 

     var _event = 
     new Event 
     { 
      Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
      DTStart = new iCalDateTime(2015, 9, 8, 10, 30, 0, pacificTimeZone.TZID, iCalendar), 
      Duration = new TimeSpan(0, 1, 0, 0) 
     }; 

     var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 

     _event.RecurrenceRules.Add(rp); 
     iCalendar.Events.Add(_event); 

     var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 
    } 

quando il debug ha ottenuto ottenuto output come

stack

è possibile modificare il fuso orario di conseguenza e ottenere il risultato. Spero che ti aiuti.

+0

Grazie. Sono a conoscenza del problema con i risparmi diurni. Come mostra la mia domanda, sto ottenendo i valori PST corretti - è l'UTC che non è corretto. Non vedo come la tua risposta risolva il mio problema. – richard

+0

Come penso che questo sia il modo in cui funziona DDay Ical. –

+0

Ok così la risposta sarebbe no, DDay Ical non calcola correttamente le occorrenze. È corretto? – richard

1

Don't use dday.ical; utilizzare ical.net.

Questo dovrebbe iniziare:

var iCalendar = new Calendar(); 

var start = new DateTime(2015, 9, 8, 10, 30, 0); 
var e = new Event 
{ 
    Summary = "This is an event at 2015-09-08 10:30 PST (2015-09-08 17:30 UTC)", 
    DtStart = new CalDateTime(start, "Pacific Standard Time"), 
    Duration = TimeSpan.FromHours(1) 
}; 

var rp = new RecurrencePattern("FREQ=WEEKLY;UNTIL=20151112T080000Z;WKST=SU;BYDAY=TU"); 
e.RecurrenceRules.Add(rp); 
iCalendar.Events.Add(e); 

var startTimeSearch = new DateTime(2015, 9, 8, 0, 0, 0, DateTimeKind.Utc); 
var endTimeSearch = new DateTime(2015, 12, 1, 00, 0, 0, DateTimeKind.Utc); 
var occurrences = iCalendar.GetOccurrences(startTimeSearch, endTimeSearch); 

Risultati:

ical-net-recurrence-result