summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSVN Migration <svn@php.net>2004-07-25 19:21:22 +0000
committerSVN Migration <svn@php.net>2004-07-25 19:21:22 +0000
commit2db28891e43a4d52dc904d6aab857a66e4aecb8e (patch)
tree5a24dba9d6627fc48d8cf63dbc4968a09d585515
parent7adc26fd8b96cee8d81b13ef48bf41776f1815ba (diff)
downloadphp-git-2db28891e43a4d52dc904d6aab857a66e4aecb8e.tar.gz
This commit was manufactured by cvs2svn to create branch 'PHP_5_0'.
-rwxr-xr-xtests/classes/autoload_005.phpt45
-rwxr-xr-xtests/classes/ctor_failure.phpt33
-rwxr-xr-xtests/classes/destructor_and_echo.phpt24
3 files changed, 102 insertions, 0 deletions
diff --git a/tests/classes/autoload_005.phpt b/tests/classes/autoload_005.phpt
new file mode 100755
index 0000000000..36a4e18f0b
--- /dev/null
+++ b/tests/classes/autoload_005.phpt
@@ -0,0 +1,45 @@
+--TEST--
+ZE2 Autoload from destructor
+--SKIPIF--
+<?php
+ if (version_compare(zend_version(), '2.0.0-dev', '<')) die('skip ZendEngine 2 needed');
+ if (class_exists('autoload_root', false)) die('skip Autoload test classes exist already');
+?>
+--FILE--
+<?php
+
+function __autoload($class_name)
+{
+ var_dump(class_exists($class_name, false));
+ require_once(dirname(__FILE__) . '/' . $class_name . '.p5c');
+ echo __FUNCTION__ . '(' . $class_name . ")\n";
+}
+
+var_dump(class_exists('autoload_derived', false));
+var_dump(class_exists('autoload_derived', false));
+
+class Test
+{
+ function __destruct() {
+ echo __METHOD__ . "\n";
+ $o = new autoload_derived;
+ var_dump($o);
+ }
+}
+
+$o = new Test;
+unset($o);
+
+?>
+===DONE===
+--EXPECTF--
+bool(false)
+bool(false)
+Test::__destruct
+bool(false)
+bool(false)
+__autoload(autoload_root)
+__autoload(autoload_derived)
+object(autoload_derived)#%d (0) {
+}
+===DONE===
diff --git a/tests/classes/ctor_failure.phpt b/tests/classes/ctor_failure.phpt
new file mode 100755
index 0000000000..bbebca2af8
--- /dev/null
+++ b/tests/classes/ctor_failure.phpt
@@ -0,0 +1,33 @@
+--TEST--
+Do not call destructors if constructor fails
+--FILE--
+<?php
+
+class Test
+{
+ function __construct($msg) {
+ echo __METHOD__ . "($msg)\n";
+ throw new Exception($msg);
+ }
+
+ function __destruct() {
+ echo __METHOD__ . "\n";
+ }
+}
+
+try
+{
+ $o = new Test('Hello');
+ unset($o);
+}
+catch (Exception $e)
+{
+ echo 'Caught ' . get_class($e) . '(' . $e->getMessage() . ")\n";
+}
+
+?>
+===DONE===
+--EXPECT--
+Test::__construct(Hello)
+Caught Exception(Hello)
+===DONE===
diff --git a/tests/classes/destructor_and_echo.phpt b/tests/classes/destructor_and_echo.phpt
new file mode 100755
index 0000000000..c6c6f23a71
--- /dev/null
+++ b/tests/classes/destructor_and_echo.phpt
@@ -0,0 +1,24 @@
+--TEST--
+Destructors and echo
+--FILE--
+<?php
+
+class Test
+{
+ function __construct() {
+ echo __METHOD__ . "\n";
+ }
+
+ function __destruct() {
+ echo __METHOD__ . "\n";
+ }
+}
+
+$o = new Test;
+
+?>
+===DONE===
+--EXPECT--
+Test::__construct
+===DONE===
+Test::__destruct