From 13db8cb25a5bbf20a5f99b32ed901818b4ef4d3b Mon Sep 17 00:00:00 2001 From: andy wharmby Date: Wed, 18 Mar 2009 11:13:04 +0000 Subject: [PATCH] New tests for date extension DateTimeZone methods Tested on Windows, Linux and linux 64 --- ext/date/tests/DateTimeZone_clone_basic1.phpt | 39 + ext/date/tests/DateTimeZone_clone_basic2.phpt | 66 ++ ext/date/tests/DateTimeZone_clone_basic3.phpt | 75 ++ ext/date/tests/DateTimeZone_clone_basic4.phpt | 28 + .../tests/DateTimeZone_compare_basic1.phpt | 54 ++ .../tests/DateTimeZone_construct_basic.phpt | 30 + .../tests/DateTimeZone_construct_error.phpt | 32 + .../DateTimeZone_construct_variation1.phpt | 200 +++++ .../tests/DateTimeZone_extends_basic1.phpt | 34 + .../tests/DateTimeZone_getName_basic1.phpt | 32 + .../tests/DateTimeZone_getName_error.phpt | 31 + .../tests/DateTimeZone_getOffset_basic1.phpt | 33 + .../tests/DateTimeZone_getOffset_error.phpt | 40 + .../DateTimeZone_getOffset_variation1.phpt | 252 ++++++ .../DateTimeZone_getTransitions_basic1.phpt | 50 ++ .../DateTimeZone_getTransitions_error.phpt | 34 + ...DateTimeZone_listAbbreviations_basic1.phpt | 70 ++ .../DateTimeZone_listIdentifiers_basic1.phpt | 828 ++++++++++++++++++ ext/date/tests/DateTimeZone_serialize.phpt | 29 + ext/date/tests/DateTimeZone_verify.phpt | 111 +++ 20 files changed, 2068 insertions(+) create mode 100644 ext/date/tests/DateTimeZone_clone_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_clone_basic2.phpt create mode 100644 ext/date/tests/DateTimeZone_clone_basic3.phpt create mode 100644 ext/date/tests/DateTimeZone_clone_basic4.phpt create mode 100644 ext/date/tests/DateTimeZone_compare_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_construct_basic.phpt create mode 100644 ext/date/tests/DateTimeZone_construct_error.phpt create mode 100644 ext/date/tests/DateTimeZone_construct_variation1.phpt create mode 100644 ext/date/tests/DateTimeZone_extends_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_getName_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_getName_error.phpt create mode 100644 ext/date/tests/DateTimeZone_getOffset_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_getOffset_error.phpt create mode 100644 ext/date/tests/DateTimeZone_getOffset_variation1.phpt create mode 100644 ext/date/tests/DateTimeZone_getTransitions_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_getTransitions_error.phpt create mode 100644 ext/date/tests/DateTimeZone_listAbbreviations_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_listIdentifiers_basic1.phpt create mode 100644 ext/date/tests/DateTimeZone_serialize.phpt create mode 100644 ext/date/tests/DateTimeZone_verify.phpt diff --git a/ext/date/tests/DateTimeZone_clone_basic1.phpt b/ext/date/tests/DateTimeZone_clone_basic1.phpt new file mode 100644 index 0000000000..6de5d4b463 --- /dev/null +++ b/ext/date/tests/DateTimeZone_clone_basic1.phpt @@ -0,0 +1,39 @@ +--TEST-- +Test clone on DateTimeZone objects +--FILE-- + +===DONE=== +--EXPECTF-- +*** Testing clone on DateTime objects *** +object(DateTimeZone)#%d (0) { +} +object(DateTimeZone)#%d (0) { +} +TEST PASSED : Objects equal but not indetical +===DONE=== + + diff --git a/ext/date/tests/DateTimeZone_clone_basic2.phpt b/ext/date/tests/DateTimeZone_clone_basic2.phpt new file mode 100644 index 0000000000..a499510ff9 --- /dev/null +++ b/ext/date/tests/DateTimeZone_clone_basic2.phpt @@ -0,0 +1,66 @@ +--TEST-- +Testing clone on objects whoose class derived from DateTimeZone class +--FILE-- + +===DONE=== +--EXPECTF-- +*** Testing clone on objects whoose class derived from DateTimeZone class *** +object(DateTimeZoneExt1)#%d (2) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} +object(DateTimeZoneExt1)#%d (2) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} +object(DateTimeZoneExt2)#%d (4) { + ["property3"]=> + bool(true) + ["property4"]=> + float(10.5) + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} +object(DateTimeZoneExt2)#%d (4) { + ["property3"]=> + bool(true) + ["property4"]=> + float(10.5) + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} +===DONE=== diff --git a/ext/date/tests/DateTimeZone_clone_basic3.phpt b/ext/date/tests/DateTimeZone_clone_basic3.phpt new file mode 100644 index 0000000000..e85f42e876 --- /dev/null +++ b/ext/date/tests/DateTimeZone_clone_basic3.phpt @@ -0,0 +1,75 @@ +--TEST-- +Test clone of DateTimeZOne objects +--FILE-- +property1 = 99; +$d1->property2 = "Hello"; +var_dump($d1); +echo "\n-- clone it --\n"; +$d1_clone = clone $d1; +var_dump($d1_clone); +echo "\n-- Add some more properties --\n"; +$d1_clone->property3 = true; +$d1_clone->property4 = 10.5; +var_dump($d1_clone); +echo "\n-- clone it --\n"; +$d2_clone = clone $d1_clone; +var_dump($d2_clone); +?> +===DONE=== +--EXPECTF-- +*** Testing clone on DateTime objects *** + +-- Create a DateTimeZone object -- +object(DateTimeZone)#%d (0) { +} + +-- Add some properties -- +object(DateTimeZone)#%d (2) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} + +-- clone it -- +object(DateTimeZone)#%d (2) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" +} + +-- Add some more properties -- +object(DateTimeZone)#%d (4) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" + ["property3"]=> + bool(true) + ["property4"]=> + float(10.5) +} + +-- clone it -- +object(DateTimeZone)#%d (4) { + ["property1"]=> + int(99) + ["property2"]=> + string(5) "Hello" + ["property3"]=> + bool(true) + ["property4"]=> + float(10.5) +} +===DONE=== diff --git a/ext/date/tests/DateTimeZone_clone_basic4.phpt b/ext/date/tests/DateTimeZone_clone_basic4.phpt new file mode 100644 index 0000000000..a295b915ce --- /dev/null +++ b/ext/date/tests/DateTimeZone_clone_basic4.phpt @@ -0,0 +1,28 @@ +--TEST-- +Test clone of DateTimeZone derived objects with __clone magic method +--FILE-- +getName() ); + +?> +===DONE=== +--EXPECTF-- +*** Testing clone of objects derived from DateTimeZone class with __clone magic method*** +-- DateTimeExt1 __clone magic method called -- +string(16) "America/New_York" +===DONE=== diff --git a/ext/date/tests/DateTimeZone_compare_basic1.phpt b/ext/date/tests/DateTimeZone_compare_basic1.phpt new file mode 100644 index 0000000000..f3648cb243 --- /dev/null +++ b/ext/date/tests/DateTimeZone_compare_basic1.phpt @@ -0,0 +1,54 @@ +--TEST-- +Test of compare object handler for DateTime objects +--FILE-- + +===DONE=== +--EXPECT-- +Simple test for DateTimeZone compare object handler + +-- All the following tests should compare equal -- +bool(true) + +-- All the following tests should compare NOT equal -- +bool(false) +bool(false) +bool(false) +bool(false) +bool(false) +bool(false) +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_construct_basic.phpt b/ext/date/tests/DateTimeZone_construct_basic.phpt new file mode 100644 index 0000000000..b681e8f9c3 --- /dev/null +++ b/ext/date/tests/DateTimeZone_construct_basic.phpt @@ -0,0 +1,30 @@ +--TEST-- +Test new DateTimeZone() : basic functionality +--FILE-- + +===DONE=== +--EXPECTF-- +*** Testing new DateTimeZone() : basic functionality *** +object(DateTimeZone)#%d (0) { +} +object(DateTimeZone)#%d (0) { +} +object(DateTimeZone)#%d (0) { +} +===DONE=== diff --git a/ext/date/tests/DateTimeZone_construct_error.phpt b/ext/date/tests/DateTimeZone_construct_error.phpt new file mode 100644 index 0000000000..8ffe322176 --- /dev/null +++ b/ext/date/tests/DateTimeZone_construct_error.phpt @@ -0,0 +1,32 @@ +--TEST-- +Test new DateTimeZone() : error conditions +--FILE-- + +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone() : error conditions *** + +-- Testing new DateTimeZone() with more than expected no. of arguments -- + +Fatal error: Uncaught exception 'Exception' with message 'DateTimeZone::__construct() expects exactly 1 parameter, 2 given' in %s:%d +Stack trace: +#0 %s(%d): DateTimeZone->__construct('GMT', 99) +#1 {main} + thrown in %s on line %d + \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_construct_variation1.phpt b/ext/date/tests/DateTimeZone_construct_variation1.phpt new file mode 100644 index 0000000000..65e575ee44 --- /dev/null +++ b/ext/date/tests/DateTimeZone_construct_variation1.phpt @@ -0,0 +1,200 @@ +--TEST-- +Test DateTime::__construct() function : usage variation - Passing unexpected values to first argument $timezone. +--FILE-- + 1, 'two' => 2); + +// resource +$file_handle = fopen(__FILE__, 'r'); + +//array of values to iterate over +$inputs = array( + + // int data + 'int 0' => 0, + 'int 1' => 1, + 'int 12345' => 12345, + 'int -12345' => -12345, + + // float data + 'float 10.5' => 10.5, + 'float -10.5' => -10.5, + 'float .5' => .5, + + // array data + 'empty array' => array(), + 'int indexed array' => $index_array, + 'associative array' => $assoc_array, + 'nested arrays' => array('foo', $index_array, $assoc_array), + + // null data + 'uppercase NULL' => NULL, + 'lowercase null' => null, + + // boolean data + 'lowercase true' => true, + 'lowercase false' =>false, + 'uppercase TRUE' =>TRUE, + 'uppercase FALSE' =>FALSE, + + // empty data + 'empty string DQ' => "", + 'empty string SQ' => '', + + // string data + 'string DQ' => "string", + 'string SQ' => 'string', + 'mixed case string' => "sTrInG", + 'heredoc' => $heredoc, + + // object data + 'instance of classWithToString' => new classWithToString(), + 'instance of classWithoutToString' => new classWithoutToString(), + + // undefined data + 'undefined var' => @$undefined_var, + + // unset data + 'unset var' => @$unset_var, + + // resource + 'resource' => $file_handle +); + +foreach($inputs as $variation =>$timezone) { + echo "\n-- $variation --\n"; + try { + var_dump( new DateTimezone($timezone) ); + } catch(Exception $e) { + $msg = $e->getMessage(); + echo "FAILED: " . $msg . "\n"; + } + +}; + +// closing the resource +fclose( $file_handle ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTime::__construct() : usage variation - unexpected values to first argument $timezone*** + +-- int 0 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (0) + +-- int 1 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (1) + +-- int 12345 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (12345) + +-- int -12345 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (-12345) + +-- float 10.5 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (10.5) + +-- float -10.5 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (-10.5) + +-- float .5 -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (0.5) + +-- empty array -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, array given + +-- int indexed array -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, array given + +-- associative array -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, array given + +-- nested arrays -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, array given + +-- uppercase NULL -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- lowercase null -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- lowercase true -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (1) + +-- lowercase false -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- uppercase TRUE -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (1) + +-- uppercase FALSE -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- empty string DQ -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- empty string SQ -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- string DQ -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (string) + +-- string SQ -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (string) + +-- mixed case string -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (sTrInG) + +-- heredoc -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (hello world) + +-- instance of classWithToString -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone (Class A object) + +-- instance of classWithoutToString -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, object given + +-- undefined var -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- unset var -- +FAILED: DateTimeZone::__construct(): Unknown or bad timezone () + +-- resource -- +FAILED: DateTimeZone::__construct() expects parameter 1 to be string, resource given +===DONE=== diff --git a/ext/date/tests/DateTimeZone_extends_basic1.phpt b/ext/date/tests/DateTimeZone_extends_basic1.phpt new file mode 100644 index 0000000000..afc2ed64b2 --- /dev/null +++ b/ext/date/tests/DateTimeZone_extends_basic1.phpt @@ -0,0 +1,34 @@ +--TEST-- +Test DateTimeZone class inheritance +--FILE-- + +===DONE=== +--EXPECTF-- +*** Testing basic DateTimeZone inheritance() *** + +-- Create an instance of DateTimeZoneExt -- + +-- Invoke __toString -- +America/Los_Angeles +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_getName_basic1.phpt b/ext/date/tests/DateTimeZone_getName_basic1.phpt new file mode 100644 index 0000000000..de5ca652d7 --- /dev/null +++ b/ext/date/tests/DateTimeZone_getName_basic1.phpt @@ -0,0 +1,32 @@ +--TEST-- +Test DateTimeZone::getName() function : basic functionality +--FILE-- +getName() ); + +$tz2 = new DateTimeZone("America/New_York"); +var_dump( $tz2->getName() ); + +$tz3 = new DateTimeZone("America/Los_Angeles"); +var_dump( $tz3->getName() ); + +?> +===DONE=== +--EXPECT-- +*** Testing DateTimeZone::getName() : basic functionality *** +string(13) "Europe/London" +string(16) "America/New_York" +string(19) "America/Los_Angeles" +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_getName_error.phpt b/ext/date/tests/DateTimeZone_getName_error.phpt new file mode 100644 index 0000000000..0a87b10069 --- /dev/null +++ b/ext/date/tests/DateTimeZone_getName_error.phpt @@ -0,0 +1,31 @@ +--TEST-- +Test DateTimeZone::getName() function : error conditions +--FILE-- +getName($extra_arg) ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone::getName() : error conditions *** + +-- Testing DateTimeZone::getName() function with more than expected no. of arguments -- + +Warning: DateTimeZone::getName() expects exactly 0 parameters, 1 given in %s on line %d +bool(false) +===DONE=== diff --git a/ext/date/tests/DateTimeZone_getOffset_basic1.phpt b/ext/date/tests/DateTimeZone_getOffset_basic1.phpt new file mode 100644 index 0000000000..46c0e6af6b --- /dev/null +++ b/ext/date/tests/DateTimeZone_getOffset_basic1.phpt @@ -0,0 +1,33 @@ +--TEST-- +Test DateTimeZone::getOffset() function : basic functionality +--FILE-- +getOffset($date) ); + +$tz2 = new DateTimeZone("America/New_York"); +var_dump( $tz2->getOffset($date) ); + +$tz3 = new DateTimeZone("America/Los_Angeles"); +var_dump( $tz3->getOffset($date) ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone::getOffset() : basic functionality *** +int(0) +%rint\(-18000\)|int\(-14400\)%r +%rint\(-28800\)|int\(-25200\)%r +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_getOffset_error.phpt b/ext/date/tests/DateTimeZone_getOffset_error.phpt new file mode 100644 index 0000000000..56e45b76d4 --- /dev/null +++ b/ext/date/tests/DateTimeZone_getOffset_error.phpt @@ -0,0 +1,40 @@ +--TEST-- +Test DateTimeZone::getOffset() function : error conditions +--FILE-- +getOffset() ); + +echo "\n-- Testing DateTimeZone::getOffset() function with more than expected no. of arguments --\n"; +$extra_arg = 99; +var_dump( $tz->getOffset($date, $extra_arg) ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone::getOffset() : error conditions *** + +-- Testing DateTimeZone::getOffset() function with zero arguments -- + +Warning: DateTimeZone::getOffset() expects exactly 1 parameter, 0 given in %s on line %d +bool(false) + +-- Testing DateTimeZone::getOffset() function with more than expected no. of arguments -- + +Warning: DateTimeZone::getOffset() expects exactly 1 parameter, 2 given in %s on line %d +bool(false) +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_getOffset_variation1.phpt b/ext/date/tests/DateTimeZone_getOffset_variation1.phpt new file mode 100644 index 0000000000..a86d5e10bb --- /dev/null +++ b/ext/date/tests/DateTimeZone_getOffset_variation1.phpt @@ -0,0 +1,252 @@ +--TEST-- +Test DateTimeZone::getOffset() function : usage variation - Passing unexpected values to first argument $datetime. +--FILE-- + 1, 'two' => 2); + +// resource +$file_handle = fopen(__FILE__, 'r'); + +//array of values to iterate over +$inputs = array( + + // int data + 'int 0' => 0, + 'int 1' => 1, + 'int 12345' => 12345, + 'int -12345' => -12345, + + // float data + 'float 10.5' => 10.5, + 'float -10.5' => -10.5, + 'float .5' => .5, + + // array data + 'empty array' => array(), + 'int indexed array' => $index_array, + 'associative array' => $assoc_array, + 'nested arrays' => array('foo', $index_array, $assoc_array), + + // null data + 'uppercase NULL' => NULL, + 'lowercase null' => null, + + // boolean data + 'lowercase true' => true, + 'lowercase false' =>false, + 'uppercase TRUE' =>TRUE, + 'uppercase FALSE' =>FALSE, + + // empty data + 'empty string DQ' => "", + 'empty string SQ' => '', + + // string data + 'string DQ' => "string", + 'string SQ' => 'string', + 'mixed case string' => "sTrInG", + 'heredoc' => $heredoc, + + // object data + 'instance of classWithToString' => new classWithToString(), + 'instance of classWithoutToString' => new classWithoutToString(), + + // undefined data + 'undefined var' => @$undefined_var, + + // unset data + 'unset var' => @$unset_var, + + // resource + 'resource' => $file_handle +); + +$timezone = new DateTimezone("Europe/London"); + +foreach($inputs as $variation =>$datetime) { + echo "\n-- $variation --\n"; + var_dump( $timezone->getOffset($datetime) ); +}; + +// closing the resource +fclose( $file_handle ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone::getOffset() : usage variation - unexpected values to first argument $datetime*** + +-- int 0 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, integer given in %s on line %d +bool(false) + +-- int 1 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, integer given in %s on line %d +bool(false) + +-- int 12345 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, integer given in %s on line %d +bool(false) + +-- int -12345 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, integer given in %s on line %d +bool(false) + +-- float 10.5 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, double given in %s on line %d +bool(false) + +-- float -10.5 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, double given in %s on line %d +bool(false) + +-- float .5 -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, double given in %s on line %d +bool(false) + +-- empty array -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, array given in %s on line %d +bool(false) + +-- int indexed array -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, array given in %s on line %d +bool(false) + +-- associative array -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, array given in %s on line %d +bool(false) + +-- nested arrays -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, array given in %s on line %d +bool(false) + +-- uppercase NULL -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, null given in %s on line %d +bool(false) + +-- lowercase null -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, null given in %s on line %d +bool(false) + +-- lowercase true -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, boolean given in %s on line %d +bool(false) + +-- lowercase false -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, boolean given in %s on line %d +bool(false) + +-- uppercase TRUE -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, boolean given in %s on line %d +bool(false) + +-- uppercase FALSE -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, boolean given in %s on line %d +bool(false) + +-- empty string DQ -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- empty string SQ -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- string DQ -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- string SQ -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- mixed case string -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- heredoc -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, string given in %s on line %d +bool(false) + +-- instance of classWithToString -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, object given in %s on line %d +bool(false) + +-- instance of classWithoutToString -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, object given in %s on line %d +bool(false) + +-- undefined var -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, null given in %s on line %d +bool(false) + +-- unset var -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, null given in %s on line %d +bool(false) + +-- resource -- + +Warning: DateTimeZone::getOffset() expects parameter 1 to be DateTime, resource given in %s on line %d +bool(false) +===DONE=== diff --git a/ext/date/tests/DateTimeZone_getTransitions_basic1.phpt b/ext/date/tests/DateTimeZone_getTransitions_basic1.phpt new file mode 100644 index 0000000000..f3640d1c1a --- /dev/null +++ b/ext/date/tests/DateTimeZone_getTransitions_basic1.phpt @@ -0,0 +1,50 @@ +--TEST-- +Test DateTimeZone::getTransitions() function : basic functionality +--FILE-- +getTransitions(); + +if (!is_array($tran)) { + echo "TEST FAILED: Expected an array\n"; +} + +echo "\n-- Total number of transitions: " . count($tran). " --\n"; + +echo "\n-- Format a sample entry for Spring 1963 --\n"; +var_dump( $tran[97] ); + +?> +===DONE=== +--EXPECT-- +*** Testing DateTimeZone::getTransitions() : basic functionality *** + +-- Total number of transitions: 243 -- + +-- Format a sample entry for Spring 1963 -- +array(5) { + ["ts"]=> + int(-213228000) + ["time"]=> + string(24) "1963-03-31T02:00:00+0000" + ["offset"]=> + int(3600) + ["isdst"]=> + bool(true) + ["abbr"]=> + string(3) "BST" +} +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_getTransitions_error.phpt b/ext/date/tests/DateTimeZone_getTransitions_error.phpt new file mode 100644 index 0000000000..bfcd224ca7 --- /dev/null +++ b/ext/date/tests/DateTimeZone_getTransitions_error.phpt @@ -0,0 +1,34 @@ +--TEST-- +Test DateTimeZone::getTransitions() function : error conditions +--FILE-- +getTransitions($timestamp_begin, $timestamp_end, $extra_arg) ); + +?> +===DONE=== +--EXPECTF-- +*** Testing DateTimeZone::getTransitions() : error conditions *** + +-- Testing DateTimeZone::getTransitions() function with more than expected no. of arguments -- + +Warning: DateTimeZone::getTransitions() expects at most 2 parameters, 3 given in %s on line %d +bool(false) +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_listAbbreviations_basic1.phpt b/ext/date/tests/DateTimeZone_listAbbreviations_basic1.phpt new file mode 100644 index 0000000000..bd6344fa24 --- /dev/null +++ b/ext/date/tests/DateTimeZone_listAbbreviations_basic1.phpt @@ -0,0 +1,70 @@ +--TEST-- +Test DateTimeZone::listAbbreviations() function : basic functionality +--FILE-- + +===DONE=== +--EXPECT-- +*** Testing DateTimeZone::listAbbreviations() : basic functionality *** +string(5) "array" +int(338) + +-- Format a sample entry -- +array(4) { + [0]=> + array(3) { + ["dst"]=> + bool(true) + ["offset"]=> + int(-14400) + ["timezone_id"]=> + string(18) "America/Porto_Acre" + } + [1]=> + array(3) { + ["dst"]=> + bool(true) + ["offset"]=> + int(-14400) + ["timezone_id"]=> + string(16) "America/Eirunepe" + } + [2]=> + array(3) { + ["dst"]=> + bool(true) + ["offset"]=> + int(-14400) + ["timezone_id"]=> + string(18) "America/Rio_Branco" + } + [3]=> + array(3) { + ["dst"]=> + bool(true) + ["offset"]=> + int(-14400) + ["timezone_id"]=> + string(11) "Brazil/Acre" + } +} +===DONE=== diff --git a/ext/date/tests/DateTimeZone_listIdentifiers_basic1.phpt b/ext/date/tests/DateTimeZone_listIdentifiers_basic1.phpt new file mode 100644 index 0000000000..c1ab2f99b7 --- /dev/null +++ b/ext/date/tests/DateTimeZone_listIdentifiers_basic1.phpt @@ -0,0 +1,828 @@ +--TEST-- +Test DateTimeZone::listIdentifiers function : basic functionality +--FILE-- + +===DONE=== +--EXPECT-- +*** Testing DateTimeZone::listIdentifiers() : basic functionality *** +array(402) { + [0]=> + string(14) "Africa/Abidjan" + [1]=> + string(12) "Africa/Accra" + [2]=> + string(18) "Africa/Addis_Ababa" + [3]=> + string(14) "Africa/Algiers" + [4]=> + string(13) "Africa/Asmara" + [5]=> + string(13) "Africa/Bamako" + [6]=> + string(13) "Africa/Bangui" + [7]=> + string(13) "Africa/Banjul" + [8]=> + string(13) "Africa/Bissau" + [9]=> + string(15) "Africa/Blantyre" + [10]=> + string(18) "Africa/Brazzaville" + [11]=> + string(16) "Africa/Bujumbura" + [12]=> + string(12) "Africa/Cairo" + [13]=> + string(17) "Africa/Casablanca" + [14]=> + string(12) "Africa/Ceuta" + [15]=> + string(14) "Africa/Conakry" + [16]=> + string(12) "Africa/Dakar" + [17]=> + string(20) "Africa/Dar_es_Salaam" + [18]=> + string(15) "Africa/Djibouti" + [19]=> + string(13) "Africa/Douala" + [20]=> + string(15) "Africa/El_Aaiun" + [21]=> + string(15) "Africa/Freetown" + [22]=> + string(15) "Africa/Gaborone" + [23]=> + string(13) "Africa/Harare" + [24]=> + string(19) "Africa/Johannesburg" + [25]=> + string(14) "Africa/Kampala" + [26]=> + string(15) "Africa/Khartoum" + [27]=> + string(13) "Africa/Kigali" + [28]=> + string(15) "Africa/Kinshasa" + [29]=> + string(12) "Africa/Lagos" + [30]=> + string(17) "Africa/Libreville" + [31]=> + string(11) "Africa/Lome" + [32]=> + string(13) "Africa/Luanda" + [33]=> + string(17) "Africa/Lubumbashi" + [34]=> + string(13) "Africa/Lusaka" + [35]=> + string(13) "Africa/Malabo" + [36]=> + string(13) "Africa/Maputo" + [37]=> + string(13) "Africa/Maseru" + [38]=> + string(14) "Africa/Mbabane" + [39]=> + string(16) "Africa/Mogadishu" + [40]=> + string(15) "Africa/Monrovia" + [41]=> + string(14) "Africa/Nairobi" + [42]=> + string(15) "Africa/Ndjamena" + [43]=> + string(13) "Africa/Niamey" + [44]=> + string(17) "Africa/Nouakchott" + [45]=> + string(18) "Africa/Ouagadougou" + [46]=> + string(17) "Africa/Porto-Novo" + [47]=> + string(15) "Africa/Sao_Tome" + [48]=> + string(14) "Africa/Tripoli" + [49]=> + string(12) "Africa/Tunis" + [50]=> + string(15) "Africa/Windhoek" + [51]=> + string(12) "America/Adak" + [52]=> + string(17) "America/Anchorage" + [53]=> + string(16) "America/Anguilla" + [54]=> + string(15) "America/Antigua" + [55]=> + string(17) "America/Araguaina" + [56]=> + string(30) "America/Argentina/Buenos_Aires" + [57]=> + string(27) "America/Argentina/Catamarca" + [58]=> + string(25) "America/Argentina/Cordoba" + [59]=> + string(23) "America/Argentina/Jujuy" + [60]=> + string(26) "America/Argentina/La_Rioja" + [61]=> + string(25) "America/Argentina/Mendoza" + [62]=> + string(30) "America/Argentina/Rio_Gallegos" + [63]=> + string(23) "America/Argentina/Salta" + [64]=> + string(26) "America/Argentina/San_Juan" + [65]=> + string(26) "America/Argentina/San_Luis" + [66]=> + string(25) "America/Argentina/Tucuman" + [67]=> + string(25) "America/Argentina/Ushuaia" + [68]=> + string(13) "America/Aruba" + [69]=> + string(16) "America/Asuncion" + [70]=> + string(16) "America/Atikokan" + [71]=> + string(13) "America/Bahia" + [72]=> + string(16) "America/Barbados" + [73]=> + string(13) "America/Belem" + [74]=> + string(14) "America/Belize" + [75]=> + string(20) "America/Blanc-Sablon" + [76]=> + string(17) "America/Boa_Vista" + [77]=> + string(14) "America/Bogota" + [78]=> + string(13) "America/Boise" + [79]=> + string(21) "America/Cambridge_Bay" + [80]=> + string(20) "America/Campo_Grande" + [81]=> + string(14) "America/Cancun" + [82]=> + string(15) "America/Caracas" + [83]=> + string(15) "America/Cayenne" + [84]=> + string(14) "America/Cayman" + [85]=> + string(15) "America/Chicago" + [86]=> + string(17) "America/Chihuahua" + [87]=> + string(18) "America/Costa_Rica" + [88]=> + string(14) "America/Cuiaba" + [89]=> + string(15) "America/Curacao" + [90]=> + string(20) "America/Danmarkshavn" + [91]=> + string(14) "America/Dawson" + [92]=> + string(20) "America/Dawson_Creek" + [93]=> + string(14) "America/Denver" + [94]=> + string(15) "America/Detroit" + [95]=> + string(16) "America/Dominica" + [96]=> + string(16) "America/Edmonton" + [97]=> + string(16) "America/Eirunepe" + [98]=> + string(19) "America/El_Salvador" + [99]=> + string(17) "America/Fortaleza" + [100]=> + string(17) "America/Glace_Bay" + [101]=> + string(15) "America/Godthab" + [102]=> + string(17) "America/Goose_Bay" + [103]=> + string(18) "America/Grand_Turk" + [104]=> + string(15) "America/Grenada" + [105]=> + string(18) "America/Guadeloupe" + [106]=> + string(17) "America/Guatemala" + [107]=> + string(17) "America/Guayaquil" + [108]=> + string(14) "America/Guyana" + [109]=> + string(15) "America/Halifax" + [110]=> + string(14) "America/Havana" + [111]=> + string(18) "America/Hermosillo" + [112]=> + string(28) "America/Indiana/Indianapolis" + [113]=> + string(20) "America/Indiana/Knox" + [114]=> + string(23) "America/Indiana/Marengo" + [115]=> + string(26) "America/Indiana/Petersburg" + [116]=> + string(25) "America/Indiana/Tell_City" + [117]=> + string(21) "America/Indiana/Vevay" + [118]=> + string(25) "America/Indiana/Vincennes" + [119]=> + string(23) "America/Indiana/Winamac" + [120]=> + string(14) "America/Inuvik" + [121]=> + string(15) "America/Iqaluit" + [122]=> + string(15) "America/Jamaica" + [123]=> + string(14) "America/Juneau" + [124]=> + string(27) "America/Kentucky/Louisville" + [125]=> + string(27) "America/Kentucky/Monticello" + [126]=> + string(14) "America/La_Paz" + [127]=> + string(12) "America/Lima" + [128]=> + string(19) "America/Los_Angeles" + [129]=> + string(14) "America/Maceio" + [130]=> + string(15) "America/Managua" + [131]=> + string(14) "America/Manaus" + [132]=> + string(15) "America/Marigot" + [133]=> + string(18) "America/Martinique" + [134]=> + string(16) "America/Mazatlan" + [135]=> + string(17) "America/Menominee" + [136]=> + string(14) "America/Merida" + [137]=> + string(19) "America/Mexico_City" + [138]=> + string(16) "America/Miquelon" + [139]=> + string(15) "America/Moncton" + [140]=> + string(17) "America/Monterrey" + [141]=> + string(18) "America/Montevideo" + [142]=> + string(16) "America/Montreal" + [143]=> + string(18) "America/Montserrat" + [144]=> + string(14) "America/Nassau" + [145]=> + string(16) "America/New_York" + [146]=> + string(15) "America/Nipigon" + [147]=> + string(12) "America/Nome" + [148]=> + string(15) "America/Noronha" + [149]=> + string(27) "America/North_Dakota/Center" + [150]=> + string(30) "America/North_Dakota/New_Salem" + [151]=> + string(14) "America/Panama" + [152]=> + string(19) "America/Pangnirtung" + [153]=> + string(18) "America/Paramaribo" + [154]=> + string(15) "America/Phoenix" + [155]=> + string(22) "America/Port-au-Prince" + [156]=> + string(21) "America/Port_of_Spain" + [157]=> + string(19) "America/Porto_Velho" + [158]=> + string(19) "America/Puerto_Rico" + [159]=> + string(19) "America/Rainy_River" + [160]=> + string(20) "America/Rankin_Inlet" + [161]=> + string(14) "America/Recife" + [162]=> + string(14) "America/Regina" + [163]=> + string(16) "America/Resolute" + [164]=> + string(18) "America/Rio_Branco" + [165]=> + string(16) "America/Santarem" + [166]=> + string(16) "America/Santiago" + [167]=> + string(21) "America/Santo_Domingo" + [168]=> + string(17) "America/Sao_Paulo" + [169]=> + string(20) "America/Scoresbysund" + [170]=> + string(16) "America/Shiprock" + [171]=> + string(21) "America/St_Barthelemy" + [172]=> + string(16) "America/St_Johns" + [173]=> + string(16) "America/St_Kitts" + [174]=> + string(16) "America/St_Lucia" + [175]=> + string(17) "America/St_Thomas" + [176]=> + string(18) "America/St_Vincent" + [177]=> + string(21) "America/Swift_Current" + [178]=> + string(19) "America/Tegucigalpa" + [179]=> + string(13) "America/Thule" + [180]=> + string(19) "America/Thunder_Bay" + [181]=> + string(15) "America/Tijuana" + [182]=> + string(15) "America/Toronto" + [183]=> + string(15) "America/Tortola" + [184]=> + string(17) "America/Vancouver" + [185]=> + string(18) "America/Whitehorse" + [186]=> + string(16) "America/Winnipeg" + [187]=> + string(15) "America/Yakutat" + [188]=> + string(19) "America/Yellowknife" + [189]=> + string(16) "Antarctica/Casey" + [190]=> + string(16) "Antarctica/Davis" + [191]=> + string(25) "Antarctica/DumontDUrville" + [192]=> + string(17) "Antarctica/Mawson" + [193]=> + string(18) "Antarctica/McMurdo" + [194]=> + string(17) "Antarctica/Palmer" + [195]=> + string(18) "Antarctica/Rothera" + [196]=> + string(21) "Antarctica/South_Pole" + [197]=> + string(16) "Antarctica/Syowa" + [198]=> + string(17) "Antarctica/Vostok" + [199]=> + string(19) "Arctic/Longyearbyen" + [200]=> + string(9) "Asia/Aden" + [201]=> + string(11) "Asia/Almaty" + [202]=> + string(10) "Asia/Amman" + [203]=> + string(11) "Asia/Anadyr" + [204]=> + string(10) "Asia/Aqtau" + [205]=> + string(11) "Asia/Aqtobe" + [206]=> + string(13) "Asia/Ashgabat" + [207]=> + string(12) "Asia/Baghdad" + [208]=> + string(12) "Asia/Bahrain" + [209]=> + string(9) "Asia/Baku" + [210]=> + string(12) "Asia/Bangkok" + [211]=> + string(11) "Asia/Beirut" + [212]=> + string(12) "Asia/Bishkek" + [213]=> + string(11) "Asia/Brunei" + [214]=> + string(15) "Asia/Choibalsan" + [215]=> + string(14) "Asia/Chongqing" + [216]=> + string(12) "Asia/Colombo" + [217]=> + string(13) "Asia/Damascus" + [218]=> + string(10) "Asia/Dhaka" + [219]=> + string(9) "Asia/Dili" + [220]=> + string(10) "Asia/Dubai" + [221]=> + string(13) "Asia/Dushanbe" + [222]=> + string(9) "Asia/Gaza" + [223]=> + string(11) "Asia/Harbin" + [224]=> + string(16) "Asia/Ho_Chi_Minh" + [225]=> + string(14) "Asia/Hong_Kong" + [226]=> + string(9) "Asia/Hovd" + [227]=> + string(12) "Asia/Irkutsk" + [228]=> + string(12) "Asia/Jakarta" + [229]=> + string(13) "Asia/Jayapura" + [230]=> + string(14) "Asia/Jerusalem" + [231]=> + string(10) "Asia/Kabul" + [232]=> + string(14) "Asia/Kamchatka" + [233]=> + string(12) "Asia/Karachi" + [234]=> + string(12) "Asia/Kashgar" + [235]=> + string(14) "Asia/Kathmandu" + [236]=> + string(12) "Asia/Kolkata" + [237]=> + string(16) "Asia/Krasnoyarsk" + [238]=> + string(17) "Asia/Kuala_Lumpur" + [239]=> + string(12) "Asia/Kuching" + [240]=> + string(11) "Asia/Kuwait" + [241]=> + string(10) "Asia/Macau" + [242]=> + string(12) "Asia/Magadan" + [243]=> + string(13) "Asia/Makassar" + [244]=> + string(11) "Asia/Manila" + [245]=> + string(11) "Asia/Muscat" + [246]=> + string(12) "Asia/Nicosia" + [247]=> + string(16) "Asia/Novosibirsk" + [248]=> + string(9) "Asia/Omsk" + [249]=> + string(9) "Asia/Oral" + [250]=> + string(15) "Asia/Phnom_Penh" + [251]=> + string(14) "Asia/Pontianak" + [252]=> + string(14) "Asia/Pyongyang" + [253]=> + string(10) "Asia/Qatar" + [254]=> + string(14) "Asia/Qyzylorda" + [255]=> + string(12) "Asia/Rangoon" + [256]=> + string(11) "Asia/Riyadh" + [257]=> + string(13) "Asia/Sakhalin" + [258]=> + string(14) "Asia/Samarkand" + [259]=> + string(10) "Asia/Seoul" + [260]=> + string(13) "Asia/Shanghai" + [261]=> + string(14) "Asia/Singapore" + [262]=> + string(11) "Asia/Taipei" + [263]=> + string(13) "Asia/Tashkent" + [264]=> + string(12) "Asia/Tbilisi" + [265]=> + string(11) "Asia/Tehran" + [266]=> + string(12) "Asia/Thimphu" + [267]=> + string(10) "Asia/Tokyo" + [268]=> + string(16) "Asia/Ulaanbaatar" + [269]=> + string(11) "Asia/Urumqi" + [270]=> + string(14) "Asia/Vientiane" + [271]=> + string(16) "Asia/Vladivostok" + [272]=> + string(12) "Asia/Yakutsk" + [273]=> + string(18) "Asia/Yekaterinburg" + [274]=> + string(12) "Asia/Yerevan" + [275]=> + string(15) "Atlantic/Azores" + [276]=> + string(16) "Atlantic/Bermuda" + [277]=> + string(15) "Atlantic/Canary" + [278]=> + string(19) "Atlantic/Cape_Verde" + [279]=> + string(14) "Atlantic/Faroe" + [280]=> + string(16) "Atlantic/Madeira" + [281]=> + string(18) "Atlantic/Reykjavik" + [282]=> + string(22) "Atlantic/South_Georgia" + [283]=> + string(18) "Atlantic/St_Helena" + [284]=> + string(16) "Atlantic/Stanley" + [285]=> + string(18) "Australia/Adelaide" + [286]=> + string(18) "Australia/Brisbane" + [287]=> + string(21) "Australia/Broken_Hill" + [288]=> + string(16) "Australia/Currie" + [289]=> + string(16) "Australia/Darwin" + [290]=> + string(15) "Australia/Eucla" + [291]=> + string(16) "Australia/Hobart" + [292]=> + string(18) "Australia/Lindeman" + [293]=> + string(19) "Australia/Lord_Howe" + [294]=> + string(19) "Australia/Melbourne" + [295]=> + string(15) "Australia/Perth" + [296]=> + string(16) "Australia/Sydney" + [297]=> + string(16) "Europe/Amsterdam" + [298]=> + string(14) "Europe/Andorra" + [299]=> + string(13) "Europe/Athens" + [300]=> + string(15) "Europe/Belgrade" + [301]=> + string(13) "Europe/Berlin" + [302]=> + string(17) "Europe/Bratislava" + [303]=> + string(15) "Europe/Brussels" + [304]=> + string(16) "Europe/Bucharest" + [305]=> + string(15) "Europe/Budapest" + [306]=> + string(15) "Europe/Chisinau" + [307]=> + string(17) "Europe/Copenhagen" + [308]=> + string(13) "Europe/Dublin" + [309]=> + string(16) "Europe/Gibraltar" + [310]=> + string(15) "Europe/Guernsey" + [311]=> + string(15) "Europe/Helsinki" + [312]=> + string(18) "Europe/Isle_of_Man" + [313]=> + string(15) "Europe/Istanbul" + [314]=> + string(13) "Europe/Jersey" + [315]=> + string(18) "Europe/Kaliningrad" + [316]=> + string(11) "Europe/Kiev" + [317]=> + string(13) "Europe/Lisbon" + [318]=> + string(16) "Europe/Ljubljana" + [319]=> + string(13) "Europe/London" + [320]=> + string(17) "Europe/Luxembourg" + [321]=> + string(13) "Europe/Madrid" + [322]=> + string(12) "Europe/Malta" + [323]=> + string(16) "Europe/Mariehamn" + [324]=> + string(12) "Europe/Minsk" + [325]=> + string(13) "Europe/Monaco" + [326]=> + string(13) "Europe/Moscow" + [327]=> + string(11) "Europe/Oslo" + [328]=> + string(12) "Europe/Paris" + [329]=> + string(16) "Europe/Podgorica" + [330]=> + string(13) "Europe/Prague" + [331]=> + string(11) "Europe/Riga" + [332]=> + string(11) "Europe/Rome" + [333]=> + string(13) "Europe/Samara" + [334]=> + string(17) "Europe/San_Marino" + [335]=> + string(15) "Europe/Sarajevo" + [336]=> + string(17) "Europe/Simferopol" + [337]=> + string(13) "Europe/Skopje" + [338]=> + string(12) "Europe/Sofia" + [339]=> + string(16) "Europe/Stockholm" + [340]=> + string(14) "Europe/Tallinn" + [341]=> + string(13) "Europe/Tirane" + [342]=> + string(15) "Europe/Uzhgorod" + [343]=> + string(12) "Europe/Vaduz" + [344]=> + string(14) "Europe/Vatican" + [345]=> + string(13) "Europe/Vienna" + [346]=> + string(14) "Europe/Vilnius" + [347]=> + string(16) "Europe/Volgograd" + [348]=> + string(13) "Europe/Warsaw" + [349]=> + string(13) "Europe/Zagreb" + [350]=> + string(17) "Europe/Zaporozhye" + [351]=> + string(13) "Europe/Zurich" + [352]=> + string(19) "Indian/Antananarivo" + [353]=> + string(13) "Indian/Chagos" + [354]=> + string(16) "Indian/Christmas" + [355]=> + string(12) "Indian/Cocos" + [356]=> + string(13) "Indian/Comoro" + [357]=> + string(16) "Indian/Kerguelen" + [358]=> + string(11) "Indian/Mahe" + [359]=> + string(15) "Indian/Maldives" + [360]=> + string(16) "Indian/Mauritius" + [361]=> + string(14) "Indian/Mayotte" + [362]=> + string(14) "Indian/Reunion" + [363]=> + string(12) "Pacific/Apia" + [364]=> + string(16) "Pacific/Auckland" + [365]=> + string(15) "Pacific/Chatham" + [366]=> + string(14) "Pacific/Easter" + [367]=> + string(13) "Pacific/Efate" + [368]=> + string(17) "Pacific/Enderbury" + [369]=> + string(15) "Pacific/Fakaofo" + [370]=> + string(12) "Pacific/Fiji" + [371]=> + string(16) "Pacific/Funafuti" + [372]=> + string(17) "Pacific/Galapagos" + [373]=> + string(15) "Pacific/Gambier" + [374]=> + string(19) "Pacific/Guadalcanal" + [375]=> + string(12) "Pacific/Guam" + [376]=> + string(16) "Pacific/Honolulu" + [377]=> + string(16) "Pacific/Johnston" + [378]=> + string(18) "Pacific/Kiritimati" + [379]=> + string(14) "Pacific/Kosrae" + [380]=> + string(17) "Pacific/Kwajalein" + [381]=> + string(14) "Pacific/Majuro" + [382]=> + string(17) "Pacific/Marquesas" + [383]=> + string(14) "Pacific/Midway" + [384]=> + string(13) "Pacific/Nauru" + [385]=> + string(12) "Pacific/Niue" + [386]=> + string(15) "Pacific/Norfolk" + [387]=> + string(14) "Pacific/Noumea" + [388]=> + string(17) "Pacific/Pago_Pago" + [389]=> + string(13) "Pacific/Palau" + [390]=> + string(16) "Pacific/Pitcairn" + [391]=> + string(14) "Pacific/Ponape" + [392]=> + string(20) "Pacific/Port_Moresby" + [393]=> + string(17) "Pacific/Rarotonga" + [394]=> + string(14) "Pacific/Saipan" + [395]=> + string(14) "Pacific/Tahiti" + [396]=> + string(14) "Pacific/Tarawa" + [397]=> + string(17) "Pacific/Tongatapu" + [398]=> + string(12) "Pacific/Truk" + [399]=> + string(12) "Pacific/Wake" + [400]=> + string(14) "Pacific/Wallis" + [401]=> + string(3) "UTC" +} +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_serialize.phpt b/ext/date/tests/DateTimeZone_serialize.phpt new file mode 100644 index 0000000000..08dd934466 --- /dev/null +++ b/ext/date/tests/DateTimeZone_serialize.phpt @@ -0,0 +1,29 @@ +--TEST-- +Test serialization of DateTimeZone objects +--FILE-- +getName() ); + +?> +===DONE=== +--EXPECTF-- +object(DateTimeZone)#%d (0) { +} +string(24) "O:12:"DateTimeZone":0:{}" +object(DateTimeZone)#%d (0) { +} + +Warning: DateTimeZone::getName(): The DateTimeZone object has not been correctly initialized by its constructor in %s on line %d +bool(false) +===DONE=== \ No newline at end of file diff --git a/ext/date/tests/DateTimeZone_verify.phpt b/ext/date/tests/DateTimeZone_verify.phpt new file mode 100644 index 0000000000..3ca09131a7 --- /dev/null +++ b/ext/date/tests/DateTimeZone_verify.phpt @@ -0,0 +1,111 @@ +--TEST-- +Test DateTimeZone class registration +--FILE-- +getMethods(); +var_dump($methods); + +echo "..and get names of all its class constants\n"; +$constants = $class->getConstants(); +var_dump($constants); +?> +===DONE=== +--EXPECTF-- +*** Verify DateTimeZone class *** +Verify DateTimeZone class registered OK +object(ReflectionClass)#%d (1) { + ["name"]=> + string(12) "DateTimeZone" +} +..and get names of all its methods +array(7) { + [0]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(11) "__construct" + ["class"]=> + string(12) "DateTimeZone" + } + [1]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(7) "getName" + ["class"]=> + string(12) "DateTimeZone" + } + [2]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(9) "getOffset" + ["class"]=> + string(12) "DateTimeZone" + } + [3]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(14) "getTransitions" + ["class"]=> + string(12) "DateTimeZone" + } + [4]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(11) "getLocation" + ["class"]=> + string(12) "DateTimeZone" + } + [5]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(17) "listAbbreviations" + ["class"]=> + string(12) "DateTimeZone" + } + [6]=> + &object(ReflectionMethod)#%d (2) { + ["name"]=> + string(15) "listIdentifiers" + ["class"]=> + string(12) "DateTimeZone" + } +} +..and get names of all its class constants +array(14) { + ["AFRICA"]=> + int(1) + ["AMERICA"]=> + int(2) + ["ANTARCTICA"]=> + int(4) + ["ARCTIC"]=> + int(8) + ["ASIA"]=> + int(16) + ["ATLANTIC"]=> + int(32) + ["AUSTRALIA"]=> + int(64) + ["EUROPE"]=> + int(128) + ["INDIAN"]=> + int(256) + ["PACIFIC"]=> + int(512) + ["UTC"]=> + int(1024) + ["ALL"]=> + int(2047) + ["ALL_WITH_BC"]=> + int(4095) + ["PER_COUNTRY"]=> + int(4096) +} +===DONE=== \ No newline at end of file -- 2.40.0