mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
ext/zip: Add some tests for methods taking callbakcs
This commit is contained in:
parent
72708f298b
commit
08784ed58a
5 changed files with 257 additions and 6 deletions
|
@ -1,5 +1,5 @@
|
||||||
--TEST--
|
--TEST--
|
||||||
registerCancelCallback
|
ZipArchive::registerCancelCallback() with a normal callback
|
||||||
--EXTENSIONS--
|
--EXTENSIONS--
|
||||||
zip
|
zip
|
||||||
--SKIPIF--
|
--SKIPIF--
|
||||||
|
@ -14,8 +14,6 @@ date.timezone=UTC
|
||||||
$dirname = dirname(__FILE__) . '/';
|
$dirname = dirname(__FILE__) . '/';
|
||||||
$file = $dirname . '__tmp_oo_cancel.zip';
|
$file = $dirname . '__tmp_oo_cancel.zip';
|
||||||
|
|
||||||
@unlink($file);
|
|
||||||
|
|
||||||
$zip = new ZipArchive;
|
$zip = new ZipArchive;
|
||||||
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
exit('failed');
|
exit('failed');
|
||||||
|
@ -33,6 +31,13 @@ var_dump($zip->getStatusString());
|
||||||
@unlink($file);
|
@unlink($file);
|
||||||
?>
|
?>
|
||||||
Done
|
Done
|
||||||
|
--CLEAN--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_cancel.zip';
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
--EXPECTF--
|
--EXPECTF--
|
||||||
bool(true)
|
bool(true)
|
||||||
bool(true)
|
bool(true)
|
||||||
|
|
47
ext/zip/tests/oo_cancel_non_int_return.phpt
Normal file
47
ext/zip/tests/oo_cancel_non_int_return.phpt
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
--TEST--
|
||||||
|
ZipArchive::registerCancelCallback() with a callback returning an incorrect type
|
||||||
|
--EXTENSIONS--
|
||||||
|
zip
|
||||||
|
--SKIPIF--
|
||||||
|
<?php
|
||||||
|
/* $Id$ */
|
||||||
|
if (!method_exists('ZipArchive', 'registerCancelCallback')) die('skip libzip too old');
|
||||||
|
?>
|
||||||
|
--INI--
|
||||||
|
date.timezone=UTC
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_cancel_incorrect_return.zip';
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
|
exit('failed');
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Register a bogus callback */
|
||||||
|
var_dump($zip->registerCancelCallback(function () {
|
||||||
|
return [];
|
||||||
|
}));
|
||||||
|
var_dump($zip->addFromString(PHP_BINARY, 'entry #1'));
|
||||||
|
|
||||||
|
var_dump($zip->close());
|
||||||
|
var_dump($zip->status == ZipArchive::ER_CANCELLED);
|
||||||
|
var_dump($zip->getStatusString());
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
|
Done
|
||||||
|
--CLEAN--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_cancel_incorrect_return.zip';
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
|
--EXPECT--
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
bool(false)
|
||||||
|
string(8) "No error"
|
||||||
|
Done
|
97
ext/zip/tests/oo_cancel_trampoline.phpt
Normal file
97
ext/zip/tests/oo_cancel_trampoline.phpt
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
--TEST--
|
||||||
|
ZipArchive::registerCancelCallback() with a trampoline
|
||||||
|
--EXTENSIONS--
|
||||||
|
zip
|
||||||
|
--SKIPIF--
|
||||||
|
<?php
|
||||||
|
/* $Id$ */
|
||||||
|
if (!method_exists('ZipArchive', 'registerCancelCallback')) die('skip libzip too old');
|
||||||
|
?>
|
||||||
|
--INI--
|
||||||
|
date.timezone=UTC
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_cancel_trampoline.zip';
|
||||||
|
|
||||||
|
class TrampolineTest {
|
||||||
|
public function __call(string $name, array $arguments): int {
|
||||||
|
echo 'Trampoline for ', $name, PHP_EOL;
|
||||||
|
if ($name === 'trampolineThrow') {
|
||||||
|
throw new Exception('boo');
|
||||||
|
}
|
||||||
|
var_dump($arguments);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$o = new TrampolineTest();
|
||||||
|
$callback = [$o, 'trampoline'];
|
||||||
|
$callbackThrow = [$o, 'trampolineThrow'];
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
|
exit('failed');
|
||||||
|
}
|
||||||
|
|
||||||
|
var_dump($zip->registerCancelCallback($callback));
|
||||||
|
var_dump($zip->addFromString(PHP_BINARY, 'entry #1'));
|
||||||
|
var_dump($zip->close());
|
||||||
|
var_dump($zip->status == ZipArchive::ER_CANCELLED);
|
||||||
|
var_dump($zip->getStatusString());
|
||||||
|
|
||||||
|
echo "Set trampoline after closed Archive:\n";
|
||||||
|
try {
|
||||||
|
var_dump($zip->registerCancelCallback($callback));
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
echo $e::class, ': ', $e->getMessage(), PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
unset($zip);
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
|
exit('failed');
|
||||||
|
}
|
||||||
|
|
||||||
|
var_dump($zip->registerCancelCallback($callbackThrow));
|
||||||
|
var_dump($zip->addFromString(PHP_BINARY, 'entry #1'));
|
||||||
|
try {
|
||||||
|
var_dump($zip->close());
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
echo $e::class, ': ', $e->getMessage(), PHP_EOL;
|
||||||
|
}
|
||||||
|
var_dump($zip->status == ZipArchive::ER_CANCELLED);
|
||||||
|
var_dump($zip->getStatusString());
|
||||||
|
@unlink($file);
|
||||||
|
|
||||||
|
?>
|
||||||
|
Done
|
||||||
|
--CLEAN--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_cancel_trampoline.zip';
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
|
--EXPECTF--
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
Trampoline for trampoline
|
||||||
|
array(0) {
|
||||||
|
}
|
||||||
|
|
||||||
|
Warning: ZipArchive::close(): Operation cancelled in %s on line %d
|
||||||
|
bool(false)
|
||||||
|
bool(true)
|
||||||
|
string(19) "Operation cancelled"
|
||||||
|
Set trampoline after closed Archive:
|
||||||
|
ValueError: Invalid or uninitialized Zip object
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
Trampoline for trampolineThrow
|
||||||
|
Exception: boo
|
||||||
|
bool(false)
|
||||||
|
string(8) "No error"
|
||||||
|
Done
|
|
@ -1,5 +1,5 @@
|
||||||
--TEST--
|
--TEST--
|
||||||
registerProgressCallback
|
ZipArchive::registerProgressCallback() with a normal callback
|
||||||
--EXTENSIONS--
|
--EXTENSIONS--
|
||||||
zip
|
zip
|
||||||
--SKIPIF--
|
--SKIPIF--
|
||||||
|
@ -14,8 +14,6 @@ date.timezone=UTC
|
||||||
$dirname = dirname(__FILE__) . '/';
|
$dirname = dirname(__FILE__) . '/';
|
||||||
$file = $dirname . '__tmp_oo_progress.zip';
|
$file = $dirname . '__tmp_oo_progress.zip';
|
||||||
|
|
||||||
@unlink($file);
|
|
||||||
|
|
||||||
$zip = new ZipArchive;
|
$zip = new ZipArchive;
|
||||||
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
exit('failed');
|
exit('failed');
|
||||||
|
@ -32,6 +30,13 @@ var_dump($zip->close());
|
||||||
unlink($file);
|
unlink($file);
|
||||||
?>
|
?>
|
||||||
Done
|
Done
|
||||||
|
--CLEAN--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_progress.zip';
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
--EXPECT--
|
--EXPECT--
|
||||||
bool(true)
|
bool(true)
|
||||||
bool(true)
|
bool(true)
|
||||||
|
|
97
ext/zip/tests/oo_progress_trampoline.phpt
Normal file
97
ext/zip/tests/oo_progress_trampoline.phpt
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
--TEST--
|
||||||
|
ZipArchive::registerProgressCallback() with a trampoline
|
||||||
|
--EXTENSIONS--
|
||||||
|
zip
|
||||||
|
--SKIPIF--
|
||||||
|
<?php
|
||||||
|
/* $Id$ */
|
||||||
|
if (!method_exists('ZipArchive', 'registerProgressCallback')) die('skip libzip too old');
|
||||||
|
?>
|
||||||
|
--INI--
|
||||||
|
date.timezone=UTC
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_progress_trampoline.zip';
|
||||||
|
|
||||||
|
class TrampolineTest {
|
||||||
|
public function __call(string $name, array $arguments): void {
|
||||||
|
echo 'Trampoline for ', $name, PHP_EOL;
|
||||||
|
if ($name === 'trampolineThrow') {
|
||||||
|
throw new Exception('boo');
|
||||||
|
}
|
||||||
|
var_dump($arguments);
|
||||||
|
$r = $arguments[0];
|
||||||
|
if ($r == 0.0) echo "start\n";
|
||||||
|
if ($r == 1.0) echo "end\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$o = new TrampolineTest();
|
||||||
|
$callback = [$o, 'trampoline'];
|
||||||
|
$callbackThrow = [$o, 'trampolineThrow'];
|
||||||
|
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
|
exit('failed');
|
||||||
|
}
|
||||||
|
var_dump($zip->registerProgressCallback(0.5, $callback));
|
||||||
|
var_dump($zip->addFromString('foo', 'entry #1'));
|
||||||
|
var_dump($zip->close());
|
||||||
|
|
||||||
|
echo "Set trampoline after closed Archive:\n";
|
||||||
|
try {
|
||||||
|
var_dump($zip->registerProgressCallback(0.5, $callback));
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
echo $e::class, ': ', $e->getMessage(), PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
unlink($file);
|
||||||
|
unset($zip);
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (!$zip->open($file, ZIPARCHIVE::CREATE)) {
|
||||||
|
exit('failed');
|
||||||
|
}
|
||||||
|
|
||||||
|
var_dump($zip->registerProgressCallback(0.5, $callbackThrow));
|
||||||
|
var_dump($zip->addFromString('foo', 'entry #1'));
|
||||||
|
try {
|
||||||
|
var_dump($zip->close());
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
echo $e::class, ': ', $e->getMessage(), PHP_EOL;
|
||||||
|
}
|
||||||
|
unlink($file);
|
||||||
|
unset($zip);
|
||||||
|
?>
|
||||||
|
Done
|
||||||
|
--CLEAN--
|
||||||
|
<?php
|
||||||
|
$dirname = dirname(__FILE__) . '/';
|
||||||
|
$file = $dirname . '__tmp_oo_progress_trampoline.zip';
|
||||||
|
|
||||||
|
@unlink($file);
|
||||||
|
?>
|
||||||
|
--EXPECT--
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
Trampoline for trampoline
|
||||||
|
array(1) {
|
||||||
|
[0]=>
|
||||||
|
float(0)
|
||||||
|
}
|
||||||
|
start
|
||||||
|
Trampoline for trampoline
|
||||||
|
array(1) {
|
||||||
|
[0]=>
|
||||||
|
float(1)
|
||||||
|
}
|
||||||
|
end
|
||||||
|
bool(true)
|
||||||
|
Set trampoline after closed Archive:
|
||||||
|
ValueError: Invalid or uninitialized Zip object
|
||||||
|
bool(true)
|
||||||
|
bool(true)
|
||||||
|
Trampoline for trampolineThrow
|
||||||
|
Exception: boo
|
||||||
|
Done
|
Loading…
Add table
Add a link
Reference in a new issue