You are here

public function DateRepeatTestCase::todoTestTimeRrule in Date 7.3

Same name and namespace in other branches
  1. 7.2 date_repeat/tests/date_repeat.test \DateRepeatTestCase::todoTestTimeRrule()

Test RRULE by time.

@todo Enable pieces of this as the options are added to the API.

BYYEARDAY, BYSETPOS, BYWEEKNO, BYHOUR, BYMINUTE, HOURLY, MINUTELY, SECONDLY have not yet been implemented in date_repeat.

File

date_repeat/tests/date_repeat.test, line 443
Test Date Repeat calculations.

Class

DateRepeatTestCase
Test date repeat functions.

Code

public function todoTestTimeRrule() {

  // @todo Add support for the BYYEARDAY keyword.
  // Every 3rd year on the 1st, 100th and 200th day for 10 occurrences:
  $date = "DTSTART;TZID=US-Eastern:19970101T090000";
  $rule = "RRULE:FREQ=YEARLY;INTERVAL=3;COUNT=10;BYYEARDAY=1,100,200";

  // ==> (1997 9:00 AM EST)January 1
  // (1997 9:00 AM EDT)April 10;July 19
  // (2000 9:00 AM EST)January 1
  // (2000 9:00 AM EDT)April 9;July 18
  // (2003 9:00 AM EST)January 1
  // (2003 9:00 AM EDT)April 10;July 19
  // (2006 9:00 AM EST)January 1
  // @todo Add support for the BYWEEKNO keyword.
  // Monday of week number 20 (where the default start of the week is Monday),
  // forever:
  $date = "DTSTART;TZID=US-Eastern:19970512T090000";
  $rule = "RRULE:FREQ=YEARLY;BYWEEKNO=20;BYDAY=MO";

  // ==> (1997 9:00 AM EDT)May 12
  // (1998 9:00 AM EDT)May 11
  // (1999 9:00 AM EDT)May 17
  // @todo Add support for the BYSETPOS keyword.
  // The 3rd instance into the month of one of Tuesday, Wednesday or
  // Thursday, for the next 3 months:
  $date = "DTSTART;TZID=US-Eastern:19970904T090000";
  $rule = "RRULE:FREQ=MONTHLY;COUNT=3;BYDAY=TU,WE,TH;BYSETPOS=3";

  // ==> (1997 9:00 AM EDT)September 4;October 7
  // (1997 9:00 AM EST)November 6
  // The 2nd to last weekday of the month:
  $date = "DTSTART;TZID=US-Eastern:19970929T090000";
  $rule = "RRULE:FREQ=MONTHLY;BYDAY=MO,TU,WE,TH,FR;BYSETPOS=-2";

  // ==> (1997 9:00 AM EDT)September 29
  // (1997 9:00 AM EST)October 30;November 27;December 30
  // (1998 9:00 AM EST)January 29;February 26;March 30
  // @todo Add support for the HOURLY keyword.
  // Every 3 hours from 9:00 AM to 5:00 PM on a specific day:
  $date = "DTSTART;TZID=US-Eastern:19970902T090000";
  $rule = "RRULE:FREQ=HOURLY;INTERVAL=3;UNTIL=19970902T170000Z";

  // ==> (September 2, 1997 EDT)09:00,12:00,15:00
  // @todo Add support for the MINUTELY keyword.
  // Every 15 minutes for 6 occurrences:
  $date = "DTSTART;TZID=US-Eastern:19970902T090000";
  $rule = "RRULE:FREQ=MINUTELY;INTERVAL=15;COUNT=6";

  // ==> (September 2, 1997 EDT)09:00,09:15,09:30,09:45,10:00,10:15
  // @todo Add support for the MINUTELY keyword.
  // Every hour and a half for 4 occurrences:
  $date = "DTSTART;TZID=US-Eastern:19970902T090000";
  $rule = "RRULE:FREQ=MINUTELY;INTERVAL=90;COUNT=4";

  // ==> (September 2, 1997 EDT)09:00,10:30;12:00;13:30
  // @todo Add support for the BYHOUR keyword.
  // Every 20 minutes from 9:00 AM to 4:40 PM every day:
  $date = "DTSTART;TZID=US-Eastern:19970902T090000";
  $rule = "RRULE:FREQ=DAILY;BYHOUR=9,10,11,12,13,14,15,16";

  // @todo Add support for the BYHOUR keyword.
  // @todo Add support for the BYMINUTE keyword.
  $rule = "RRULE:FREQ=DAILY;BYHOUR=9,10,11,12,13,14,15,16;BYMINUTE=0,20,40";

  // or.
  // @todo Add support for the BYHOUR keyword.
  // @todo Add support for the MINUTELY keyword.
  $rule = "RRULE:FREQ=MINUTELY;INTERVAL=20;BYHOUR=9,10,11,12,13,14,15,16";

  // ==> (September 2, 1997 EDT)9:00,9:20,9:40,10:00,10:20,16:00,16:20,16:40
  // (September 3, 1997 EDT)9:00,9:20,9:40,10:00,10:20,16:00,16:20,16:40
  // @todo Add support for the SECONDLY keyword.
  // @todo Add a test to check the SECONDLY keyword.
}