summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSanjay Mantoor <smantoor@php.net>2008-12-15 08:23:58 +0000
committerSanjay Mantoor <smantoor@php.net>2008-12-15 08:23:58 +0000
commit29c885c8bdd7547fba472c60b6a25ead2dc8e588 (patch)
tree5376f52ec20d6d7ab387c834a10649934e8e7e5f
parentc9e793df5e07eb164ede1d7dd6c0d7a8ba8b3ff6 (diff)
downloadphp-git-29c885c8bdd7547fba472c60b6a25ead2dc8e588.tar.gz
New testcases for gettimeofday function
-rw-r--r--ext/date/tests/gettimeofday_basic.phpt55
-rw-r--r--ext/date/tests/gettimeofday_error.phpt29
-rw-r--r--ext/date/tests/gettimeofday_variation1.phpt284
3 files changed, 368 insertions, 0 deletions
diff --git a/ext/date/tests/gettimeofday_basic.phpt b/ext/date/tests/gettimeofday_basic.phpt
new file mode 100644
index 0000000000..fe04f015e5
--- /dev/null
+++ b/ext/date/tests/gettimeofday_basic.phpt
@@ -0,0 +1,55 @@
+--TEST--
+Test gettimeofday() function : basic functionality
+--FILE--
+<?php
+/* Prototype : array gettimeofday([bool get_as_float])
+ * Description: Returns the current time as array
+ * Source code: ext/standard/microtime.c
+ * Alias to functions:
+ */
+
+echo "*** Testing gettimeofday() : basic functionality ***\n";
+
+date_default_timezone_set("Asia/Calcutta");
+
+// Initialise all required variables
+$get_as_float = true;
+
+// Calling gettimeofday() with all possible arguments
+var_dump( gettimeofday($get_as_float) );
+
+// Calling gettimeofday() with mandatory arguments
+var_dump( gettimeofday() );
+
+// Initialise all required variables
+$get_as_float = false;
+
+// Calling gettimeofday() with all possible arguments
+var_dump( gettimeofday($get_as_float) );
+
+?>
+===DONE===
+--EXPECTF--
+*** Testing gettimeofday() : basic functionality ***
+float(%f)
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+===DONE===
diff --git a/ext/date/tests/gettimeofday_error.phpt b/ext/date/tests/gettimeofday_error.phpt
new file mode 100644
index 0000000000..558a381fe3
--- /dev/null
+++ b/ext/date/tests/gettimeofday_error.phpt
@@ -0,0 +1,29 @@
+--TEST--
+Test gettimeofday() function : error conditions
+--FILE--
+<?php
+/* Prototype : array gettimeofday([bool get_as_float])
+ * Description: Returns the current time as array
+ * Source code: ext/standard/microtime.c
+ * Alias to functions:
+ */
+
+echo "*** Testing gettimeofday() : error conditions ***\n";
+
+
+//Test gettimeofday with one more than the expected number of arguments
+echo "\n-- Testing gettimeofday() function with more than expected no. of arguments --\n";
+$get_as_float = true;
+$extra_arg = 10;
+var_dump( gettimeofday($get_as_float, $extra_arg) );
+
+?>
+===DONE===
+--EXPECTF--
+*** Testing gettimeofday() : error conditions ***
+
+-- Testing gettimeofday() function with more than expected no. of arguments --
+
+Warning: gettimeofday() expects at most 1 parameter, 2 given in %s on line %d
+NULL
+===DONE===
diff --git a/ext/date/tests/gettimeofday_variation1.phpt b/ext/date/tests/gettimeofday_variation1.phpt
new file mode 100644
index 0000000000..f494a25b53
--- /dev/null
+++ b/ext/date/tests/gettimeofday_variation1.phpt
@@ -0,0 +1,284 @@
+--TEST--
+Test gettimeofday() function : usage variation - Passing unexpected values to get_as_float argument
+--FILE--
+<?php
+/* Prototype : array gettimeofday([bool get_as_float])
+ * Description: Returns the current time as array
+ * Source code: ext/standard/microtime.c
+ * Alias to functions:
+ */
+
+echo "*** Testing gettimeofday() : usage variation ***\n";
+
+date_default_timezone_set("Asia/Calcutta");
+
+//get an unset variable
+$unset_var = 10;
+unset ($unset_var);
+
+// define some classes
+class classWithToString
+{
+ public function __toString() {
+ return "Class A object";
+ }
+}
+
+class classWithoutToString
+{
+}
+
+// heredoc string
+$heredoc = <<<EOT
+hello world
+EOT;
+
+// add arrays
+$index_array = array (1, 2, 3);
+$assoc_array = array ('one' => 1, 'two' => 2);
+
+//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 12.3456789000e10' => 12.3456789000e10,
+ 'float -12.3456789000e10' => -12.3456789000e10,
+ '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,
+);
+
+// loop through each element of the array for get_as_float
+
+foreach($inputs as $key =>$value) {
+ echo "\n--$key--\n";
+ var_dump( gettimeofday($value) );
+};
+
+?>
+===DONE===
+--EXPECTF--
+*** Testing gettimeofday() : usage variation ***
+
+--int 0--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--int 1--
+float(%f)
+
+--int 12345--
+float(%f)
+
+--int -12345--
+float(%f)
+
+--float 10.5--
+float(%f)
+
+--float -10.5--
+float(%f)
+
+--float 12.3456789000e10--
+float(%f)
+
+--float -12.3456789000e10--
+float(%f)
+
+--float .5--
+float(%f)
+
+--empty array--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, array given in %s on line %d
+NULL
+
+--int indexed array--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, array given in %s on line %d
+NULL
+
+--associative array--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, array given in %s on line %d
+NULL
+
+--nested arrays--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, array given in %s on line %d
+NULL
+
+--uppercase NULL--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--lowercase null--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--lowercase true--
+float(%f)
+
+--lowercase false--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--uppercase TRUE--
+float(%f)
+
+--uppercase FALSE--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--empty string DQ--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--empty string SQ--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--string DQ--
+float(%f)
+
+--string SQ--
+float(%f)
+
+--mixed case string--
+float(%f)
+
+--heredoc--
+float(%f)
+
+--instance of classWithToString--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, object given in %s on line %d
+NULL
+
+--instance of classWithoutToString--
+
+Warning: gettimeofday() expects parameter 1 to be boolean, object given in %s on line %d
+NULL
+
+--undefined var--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+
+--unset var--
+array(4) {
+ ["sec"]=>
+ int(%d)
+ ["usec"]=>
+ int(%d)
+ ["minuteswest"]=>
+ int(-330)
+ ["dsttime"]=>
+ int(0)
+}
+===DONE===