summaryrefslogtreecommitdiff
path: root/tests/classes/factory_and_singleton_001.phpt
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2013-03-14 05:42:27 +0000
committer <>2013-04-03 16:25:08 +0000
commitc4dd7a1a684490673e25aaf4fabec5df138854c4 (patch)
tree4d57c44caae4480efff02b90b9be86f44bf25409 /tests/classes/factory_and_singleton_001.phpt
downloadphp2-master.tar.gz
Imported from /home/lorry/working-area/delta_php2/php-5.4.13.tar.bz2.HEADphp-5.4.13master
Diffstat (limited to 'tests/classes/factory_and_singleton_001.phpt')
-rw-r--r--tests/classes/factory_and_singleton_001.phpt101
1 files changed, 101 insertions, 0 deletions
diff --git a/tests/classes/factory_and_singleton_001.phpt b/tests/classes/factory_and_singleton_001.phpt
new file mode 100644
index 0000000..70fa020
--- /dev/null
+++ b/tests/classes/factory_and_singleton_001.phpt
@@ -0,0 +1,101 @@
+--TEST--
+ZE2 factory and singleton, test 1
+--SKIPIF--
+<?php if (version_compare(zend_version(), '2.0.0-dev', '<')) die('skip ZendEngine 2 needed'); ?>
+--FILE--
+<?php
+class test {
+ protected $x;
+
+ static private $test = NULL;
+ static private $cnt = 0;
+
+ static function factory($x) {
+ if (test::$test) {
+ return test::$test;
+ } else {
+ test::$test = new test($x);
+ return test::$test;
+ }
+ }
+
+ protected function __construct($x) {
+ test::$cnt++;
+ $this->x = $x;
+ }
+
+ static function destroy() {
+ test::$test = NULL;
+ }
+
+ protected function __destruct() {
+ test::$cnt--;
+ }
+
+ public function get() {
+ return $this->x;
+ }
+
+ static public function getX() {
+ if (test::$test) {
+ return test::$test->x;
+ } else {
+ return NULL;
+ }
+ }
+
+ static public function count() {
+ return test::$cnt;
+ }
+}
+
+echo "Access static members\n";
+var_dump(test::getX());
+var_dump(test::count());
+
+echo "Create x and y\n";
+$x = test::factory(1);
+$y = test::factory(2);
+var_dump(test::getX());
+var_dump(test::count());
+var_dump($x->get());
+var_dump($y->get());
+
+echo "Destruct x\n";
+$x = NULL;
+var_dump(test::getX());
+var_dump(test::count());
+var_dump($y->get());
+
+echo "Destruct y\n";
+$y = NULL;
+var_dump(test::getX());
+var_dump(test::count());
+
+echo "Destruct static\n";
+test::destroy();
+var_dump(test::getX());
+var_dump(test::count());
+
+echo "Done\n";
+?>
+--EXPECT--
+Access static members
+NULL
+int(0)
+Create x and y
+int(1)
+int(1)
+int(1)
+int(1)
+Destruct x
+int(1)
+int(1)
+int(1)
+Destruct y
+int(1)
+int(1)
+Destruct static
+NULL
+int(0)
+Done