summaryrefslogtreecommitdiff
path: root/ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt
diff options
context:
space:
mode:
Diffstat (limited to 'ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt')
-rw-r--r--ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt50
1 files changed, 50 insertions, 0 deletions
diff --git a/ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt b/ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt
new file mode 100644
index 0000000..1cf3e61
--- /dev/null
+++ b/ext/reflection/tests/ReflectionClass_isInstantiable_variation.phpt
@@ -0,0 +1,50 @@
+--TEST--
+ReflectionClass::IsInstantiable()
+--FILE--
+<?php
+class noCtor {
+}
+
+class publicCtorNew {
+ public function __construct() {}
+}
+
+class protectedCtorNew {
+ protected function __construct() {}
+}
+
+class privateCtorNew {
+ private function __construct() {}
+}
+
+class publicCtorOld {
+ public function publicCtorOld() {}
+}
+
+class protectedCtorOld {
+ protected function protectedCtorOld() {}
+}
+
+class privateCtorOld {
+ private function privateCtorOld() {}
+}
+
+
+$classes = array("noCtor", "publicCtorNew", "protectedCtorNew", "privateCtorNew",
+ "publicCtorOld", "protectedCtorOld", "privateCtorOld");
+
+foreach($classes as $class ) {
+ $reflectionClass = new ReflectionClass($class);
+ echo "Is $class instantiable? ";
+ var_dump($reflectionClass->IsInstantiable());
+}
+
+?>
+--EXPECTF--
+Is noCtor instantiable? bool(true)
+Is publicCtorNew instantiable? bool(true)
+Is protectedCtorNew instantiable? bool(false)
+Is privateCtorNew instantiable? bool(false)
+Is publicCtorOld instantiable? bool(true)
+Is protectedCtorOld instantiable? bool(false)
+Is privateCtorOld instantiable? bool(false)