diff vendor/phpspec/prophecy/spec/Prophecy/Doubler/ClassPatch/ReflectionClassNewInstancePatchSpec.php @ 0:4c8ae668cc8c

Initial import (non-working)
author Chris Cannam
date Wed, 29 Nov 2017 16:09:58 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/vendor/phpspec/prophecy/spec/Prophecy/Doubler/ClassPatch/ReflectionClassNewInstancePatchSpec.php	Wed Nov 29 16:09:58 2017 +0000
@@ -0,0 +1,43 @@
+<?php
+
+namespace spec\Prophecy\Doubler\ClassPatch;
+
+use PhpSpec\ObjectBehavior;
+use Prophecy\Argument;
+use Prophecy\Doubler\Generator\Node\ArgumentNode;
+use Prophecy\Doubler\Generator\Node\ClassNode;
+use Prophecy\Doubler\Generator\Node\MethodNode;
+
+class ReflectionClassNewInstancePatchSpec extends ObjectBehavior
+{
+    function it_is_a_patch()
+    {
+        $this->shouldBeAnInstanceOf('Prophecy\Doubler\ClassPatch\ClassPatchInterface');
+    }
+
+    function its_priority_is_50()
+    {
+        $this->getPriority()->shouldReturn(50);
+    }
+
+    function it_supports_ReflectionClass_only(ClassNode $reflectionClassNode, ClassNode $anotherClassNode)
+    {
+        $reflectionClassNode->getParentClass()->willReturn('ReflectionClass');
+        $anotherClassNode->getParentClass()->willReturn('stdClass');
+
+        $this->supports($reflectionClassNode)->shouldReturn(true);
+        $this->supports($anotherClassNode)->shouldReturn(false);
+    }
+
+    function it_makes_all_newInstance_arguments_optional(
+        ClassNode $class,
+        MethodNode $method,
+        ArgumentNode $arg1
+    ) {
+        $class->getMethod('newInstance')->willReturn($method);
+        $method->getArguments()->willReturn(array($arg1));
+        $arg1->setDefault(null)->shouldBeCalled();
+
+        $this->apply($class);
+    }
+}