]> granicus.if.org Git - php/commitdiff
fix test
authorAntony Dovgal <tony2001@php.net>
Fri, 16 Dec 2005 15:52:09 +0000 (15:52 +0000)
committerAntony Dovgal <tony2001@php.net>
Fri, 16 Dec 2005 15:52:09 +0000 (15:52 +0000)
add new one for 64bit only

ext/standard/tests/array/bug35014.phpt
ext/standard/tests/array/bug35014_64bit.phpt [new file with mode: 0644]

index 213bacae3c4bf19630f6c47d248b1bac8182c4ea..99ef0f7eba31d6c838a7765281c2097126801281 100644 (file)
@@ -1,5 +1,7 @@
 --TEST--
-Bug #35014 (array_product() always returns 0)
+Bug #35014 (array_product() always returns 0) (32bit)
+--SKIPIF--
+<?php if (PHP_INT_SIZE != 4) die("skip this test is for 32bit platform only"); ?>
 --INI--
 precision=14
 --FILE--
@@ -22,7 +24,7 @@ foreach ($tests as $v) {
 ?>
 --EXPECTF--    
 
-Warning: array_product(): The argument should be an array in %s/bug35014.php on line 15
+Warning: array_product(): The argument should be an array in %s on line %d
 NULL
 int(0)
 int(0)
diff --git a/ext/standard/tests/array/bug35014_64bit.phpt b/ext/standard/tests/array/bug35014_64bit.phpt
new file mode 100644 (file)
index 0000000..a5b8da8
--- /dev/null
@@ -0,0 +1,36 @@
+--TEST--
+Bug #35014 (array_product() always returns 0) (64bit)
+--SKIPIF--
+<?php if (PHP_INT_SIZE != 8) die("skip this test is for 64bit platform only"); ?>
+--INI--
+precision=14
+--FILE--
+<?php
+$tests = array(
+       'foo',
+       array(),
+       array(0),
+       array(3),
+       array(3, 3),
+       array(0.5, 2),
+       array(99999999, 99999999),
+       array(8.993, 7443241,988, sprintf("%u", -1)+0.44),
+       array(2,sprintf("%u", -1)),
+);
+
+foreach ($tests as $v) {
+       var_dump(array_product($v));
+}
+?>
+--EXPECTF--    
+
+Warning: array_product(): The argument should be an array in %s on line %d
+NULL
+int(0)
+int(0)
+int(3)
+int(9)
+float(1)
+int(9999999800000001)
+float(2.8404260053903E+20)
+int(8589934590)