!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache/2.2.22 (Debian). PHP/5.6.36 

uname -a: Linux h05.hvosting.ua 4.9.110-amd64 #3 SMP Sun Nov 4 16:27:09 UTC 2018 x86_64 

uid=1389(h33678) gid=1099(h33678) groups=1099(h33678),502(mgrsecure) 

Safe-mode: OFF (not secure)

/home/h33678/data/www/it-man.ztu.edu.ua/src/vendor/phpspec/prophecy/spec/Prophecy/Doubler/Generator/   drwxr-xr-x
Free 117.42 GB of 200.55 GB (58.55%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     ClassMirrorSpec.php (30.96 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace spec\Prophecy\Doubler\Generator;

use 
I\Simply;
use 
PhpSpec\ObjectBehavior;
use 
ReflectionClass;
use 
ReflectionMethod;
use 
ReflectionParameter;

class 
ClassMirrorSpec extends ObjectBehavior
{
    
/**
     * @param ReflectionClass  $class
     * @param ReflectionClass  $parent
     * @param ReflectionMethod $method1
     * @param ReflectionMethod $method2
     * @param ReflectionMethod $method3
     */
    
function it_reflects_a_class_by_mirroring_all_its_public_methods(
        
$class$parent$method1$method2$method3
    
)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->getParentClass()->willReturn($parent);
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array(
            
$method1$method2$method3
        
));

        
$parent->getName()->willReturn('Custom\ParentClassName');

        
$method1->getDeclaringClass()->willReturn($class);
        
$method2->getDeclaringClass()->willReturn($class);
        
$method3->getDeclaringClass()->willReturn($class);

        
$method1->getName()->willReturn('getName');
        
$method2->getName()->willReturn('getSelf');
        
$method3->getName()->willReturn('getParent');

        
$method1->isFinal()->willReturn(false);
        
$method2->isFinal()->willReturn(false);
        
$method3->isFinal()->willReturn(false);

        
$method1->isProtected()->willReturn(false);
        
$method2->isProtected()->willReturn(false);
        
$method3->isProtected()->willReturn(false);

        
$method1->isStatic()->willReturn(false);
        
$method2->isStatic()->willReturn(false);
        
$method3->isStatic()->willReturn(false);

        
$method1->returnsReference()->willReturn(false);
        
$method2->returnsReference()->willReturn(false);
        
$method3->returnsReference()->willReturn(false);

        
$method1->getParameters()->willReturn(array());
        
$method2->getParameters()->willReturn(array());
        
$method3->getParameters()->willReturn(array());

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method1->hasReturnType()->willReturn(true);
            
$method1->getReturnType()->willReturn('string');
            
$method2->hasReturnType()->willReturn(true);
            
$method2->getReturnType()->willReturn('self');
            
$method3->hasReturnType()->willReturn(true);
            
$method3->getReturnType()->willReturn('parent');
        }

        
$classNode   $this->reflect($class, array());
        
$classNode->shouldBeAnInstanceOf('Prophecy\Doubler\Generator\Node\ClassNode');
        
$classNode->getParentClass()->shouldReturn('Custom\ClassName');

        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(3);

        
$classNode->hasMethod('getName')->shouldReturn(true);
        
$classNode->hasMethod('getSelf')->shouldReturn(true);
        
$classNode->hasMethod('getParent')->shouldReturn(true);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$classNode->getMethod('getName')->getReturnType()->shouldReturn('string');
            
$classNode->getMethod('getSelf')->getReturnType()->shouldReturn('\Custom\ClassName');
            
$classNode->getMethod('getParent')->getReturnType()->shouldReturn('\Custom\ParentClassName');
        }
    }

    
/**
     * @param ReflectionClass     $class
     * @param ReflectionMethod    $method
     * @param ReflectionParameter $parameter
     */
    
function it_changes_argument_names_if_they_are_varying($class$method$parameter)
    {

        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());

        
$method->getParameters()->willReturn(array($parameter));
        
$method->getName()->willReturn('methodName');
        
$method->isFinal()->willReturn(false);
        
$method->isProtected()->willReturn(false);
        
$method->isStatic()->willReturn(false);
        
$method->returnsReference()->willReturn(false);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$parameter->getName()->willReturn('...');
        
$parameter->isDefaultValueAvailable()->willReturn(true);
        
$parameter->getDefaultValue()->willReturn(null);
        
$parameter->isPassedByReference()->willReturn(false);
        
$parameter->getClass()->willReturn($class);
        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$parameter->isVariadic()->willReturn(false);
        }

        
$classNode $this->reflect($class, array());

        
$methodNodes $classNode->getMethods();

        
$argumentNodes $methodNodes['methodName']->getArguments();
        
$argumentNode $argumentNodes[0];

        
$argumentNode->getName()->shouldReturn('__dot_dot_dot__');
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method
     */
    
function it_reflects_protected_abstract_methods($class$method)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array($method));
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array());

        
$method->isProtected()->willReturn(true);
        
$method->isStatic()->willReturn(false);
        
$method->getParameters()->willReturn(array());
        
$method->getName()->willReturn('innerDetail');
        
$method->returnsReference()->willReturn(false);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$classNode   $this->reflect($class, array());
        
$classNode->shouldBeAnInstanceOf('Prophecy\Doubler\Generator\Node\ClassNode');
        
$classNode->getParentClass()->shouldReturn('Custom\ClassName');

        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(1);

        
$methodNodes['innerDetail']->getVisibility()->shouldReturn('protected');
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method
     */
    
function it_reflects_public_static_methods($class$method)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array($method));
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array());

        
$method->isProtected()->willReturn(true);
        
$method->isStatic()->willReturn(true);
        
$method->getParameters()->willReturn(array());
        
$method->getName()->willReturn('innerDetail');
        
$method->returnsReference()->willReturn(false);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$classNode   $this->reflect($class, array());
        
$classNode->shouldBeAnInstanceOf('Prophecy\Doubler\Generator\Node\ClassNode');
        
$classNode->getParentClass()->shouldReturn('Custom\ClassName');

        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(1);

        
$methodNodes['innerDetail']->getVisibility()->shouldReturn('protected');
        
$methodNodes['innerDetail']->isStatic()->shouldReturn(true);
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $constructMethod
     * @param ReflectionMethod $destructMethod
     * @param ReflectionMethod $sleepMethod
     * @param ReflectionMethod $wakeupMethod
     * @param ReflectionMethod $toStringMethod
     * @param ReflectionMethod $callMethod
     * @param ReflectionMethod $invokeMethod
     */
    
function it_reflects_allowed_magic_methods($class$constructMethod$destructMethod$sleepMethod$wakeupMethod$toStringMethod$callMethod$invokeMethod)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array(
            
$constructMethod$destructMethod$sleepMethod$wakeupMethod$toStringMethod$callMethod$invokeMethod
        
));

        
$constructMethod->getName()->willReturn('__construct');
        
$destructMethod->getName()->willReturn('__destruct');
        
$sleepMethod->getName()->willReturn('__sleep');
        
$wakeupMethod->getName()->willReturn('__wakeup');
        
$toStringMethod->getName()->willReturn('__toString');
        
$callMethod->getName()->willReturn('__call');
        
$invokeMethod->getName()->willReturn('__invoke');

        
$constructMethod->isFinal()->willReturn(false);
        
$destructMethod->isFinal()->willReturn(false);
        
$sleepMethod->isFinal()->willReturn(false);
        
$wakeupMethod->isFinal()->willReturn(false);
        
$toStringMethod->isFinal()->willReturn(false);
        
$callMethod->isFinal()->willReturn(false);
        
$invokeMethod->isFinal()->willReturn(false);

        
$constructMethod->isProtected()->willReturn(false);
        
$destructMethod->isProtected()->willReturn(false);
        
$sleepMethod->isProtected()->willReturn(false);
        
$wakeupMethod->isProtected()->willReturn(false);
        
$toStringMethod->isProtected()->willReturn(false);
        
$callMethod->isProtected()->willReturn(false);
        
$invokeMethod->isProtected()->willReturn(false);

        
$constructMethod->isStatic()->willReturn(false);
        
$destructMethod->isStatic()->willReturn(false);
        
$sleepMethod->isStatic()->willReturn(false);
        
$wakeupMethod->isStatic()->willReturn(false);
        
$toStringMethod->isStatic()->willReturn(false);
        
$callMethod->isStatic()->willReturn(false);
        
$invokeMethod->isStatic()->willReturn(false);

        
$constructMethod->returnsReference()->willReturn(false);
        
$destructMethod->returnsReference()->willReturn(false);
        
$sleepMethod->returnsReference()->willReturn(false);
        
$wakeupMethod->returnsReference()->willReturn(false);
        
$toStringMethod->returnsReference()->willReturn(false);
        
$callMethod->returnsReference()->willReturn(false);
        
$invokeMethod->returnsReference()->willReturn(false);

        
$constructMethod->getParameters()->willReturn(array());
        
$destructMethod->getParameters()->willReturn(array());
        
$sleepMethod->getParameters()->willReturn(array());
        
$wakeupMethod->getParameters()->willReturn(array());
        
$toStringMethod->getParameters()->willReturn(array());
        
$callMethod->getParameters()->willReturn(array());
        
$invokeMethod->getParameters()->willReturn(array());

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$constructMethod->hasReturnType()->willReturn(false);
            
$destructMethod->hasReturnType()->willReturn(false);
            
$sleepMethod->hasReturnType()->willReturn(false);
            
$wakeupMethod->hasReturnType()->willReturn(false);
            
$toStringMethod->hasReturnType()->willReturn(false);
            
$callMethod->hasReturnType()->willReturn(false);
            
$invokeMethod->hasReturnType()->willReturn(false);
        }

        
$classNode   $this->reflect($class, array());
        
$classNode->shouldBeAnInstanceOf('Prophecy\Doubler\Generator\Node\ClassNode');
        
$classNode->getParentClass()->shouldReturn('Custom\ClassName');

        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(7);
    }

    
/**
     * @param ReflectionClass     $class
     * @param ReflectionMethod    $method
     * @param ReflectionParameter $param1
     * @param ReflectionParameter $param2
     * @param ReflectionClass     $typeHint
     * @param ReflectionParameter $param3
     * @param ReflectionParameter $param4
     */
    
function it_properly_reads_methods_arguments_with_types(
        
$class$method$param1$param2$typeHint$param3$param4
    
)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->getName()->willReturn('methodWithArgs');
        
$method->isFinal()->willReturn(false);
        
$method->isProtected()->willReturn(true);
        
$method->isStatic()->willReturn(false);
        
$method->returnsReference()->willReturn(false);
        
$method->getParameters()->willReturn(array($param1$param2$param3$param4));

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$param1->getName()->willReturn('arg_1');
        
$param1->isArray()->willReturn(true);
        
$param1->getClass()->willReturn(null);
        
$param1->isDefaultValueAvailable()->willReturn(true);
        
$param1->isPassedByReference()->willReturn(false);
        
$param1->allowsNull()->willReturn(false);
        
$param1->getDefaultValue()->willReturn(array());

        
$param2->getName()->willReturn('arg2');
        
$param2->isArray()->willReturn(false);
        
$param2->getClass()->willReturn($typeHint);
        
$param2->isDefaultValueAvailable()->willReturn(false);
        
$param2->isOptional()->willReturn(false);
        
$param2->isPassedByReference()->willReturn(false);
        
$param2->allowsNull()->willReturn(false);
        
$typeHint->getName()->willReturn('ArrayAccess');

        
$param3->getName()->willReturn('arg_3');
        
$param3->isArray()->willReturn(false);
        if (
version_compare(PHP_VERSION'5.4''>=')) {
            
$param3->isCallable()->willReturn(true);
        }
        
$param3->getClass()->willReturn(null);
        
$param3->isOptional()->willReturn(false);
        
$param3->isDefaultValueAvailable()->willReturn(false);
        
$param3->isPassedByReference()->willReturn(false);
        
$param3->allowsNull()->willReturn(true);

        
$param4->getName()->willReturn('arg_4');
        
$param4->isArray()->willReturn(false);
        
$param4->getClass()->willReturn($typeHint);
        
$param4->isPassedByReference()->willReturn(false);
        
$param4->allowsNull()->willReturn(true);

        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$param1->isVariadic()->willReturn(false);
            
$param2->isVariadic()->willReturn(false);
            
$param3->isVariadic()->willReturn(false);
            
$param4->isVariadic()->willReturn(true);
        } else {
            
$param4->isOptional()->willReturn(true);
            
$param4->isDefaultValueAvailable()->willReturn(false);
        }

        
$classNode   $this->reflect($class, array());
        
$methodNodes $classNode->getMethods();
        
$argNodes    $methodNodes['methodWithArgs']->getArguments();

        
$argNodes[0]->getName()->shouldReturn('arg_1');
        
$argNodes[0]->getTypeHint()->shouldReturn('array');
        
$argNodes[0]->isOptional()->shouldReturn(true);
        
$argNodes[0]->getDefault()->shouldReturn(array());

        
$argNodes[1]->getName()->shouldReturn('arg2');
        
$argNodes[1]->getTypeHint()->shouldReturn('ArrayAccess');
        
$argNodes[1]->isOptional()->shouldReturn(false);

        
$argNodes[2]->getName()->shouldReturn('arg_3');
        if (
version_compare(PHP_VERSION'5.4''>=')) {
            
$argNodes[2]->getTypeHint()->shouldReturn('callable');
            
$argNodes[2]->isOptional()->shouldReturn(true);
            
$argNodes[2]->getDefault()->shouldReturn(null);
        } else {
            
$argNodes[2]->isOptional()->shouldReturn(false);
        }

        
$argNodes[3]->getName()->shouldReturn('arg_4');
        
$argNodes[3]->getTypeHint()->shouldReturn('ArrayAccess');
        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$argNodes[3]->isVariadic()->shouldReturn(true);
        } else {
            
$argNodes[3]->isOptional()->shouldReturn(true);
            
$argNodes[3]->getDefault()->shouldReturn(null);
        }
    }

    
/**
     * @param ReflectionClass     $class
     * @param ReflectionMethod    $method
     * @param ReflectionParameter $param1
     */
    
function it_marks_required_args_without_types_as_not_optional(
        
$class$method$param1
    
)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->getName()->willReturn('methodWithArgs');
        
$method->isFinal()->willReturn(false);
        
$method->isProtected()->willReturn(false);
        
$method->isStatic()->willReturn(false);
        
$method->returnsReference()->willReturn(false);
        
$method->getParameters()->willReturn(array($param1));

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$param1->getName()->willReturn('arg_1');
        
$param1->isArray()->willReturn(false);
        if (
version_compare(PHP_VERSION'5.4''>=')) {
            
$param1->isCallable()->willReturn(false);
        }
        
$param1->getClass()->willReturn(null);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$param1->hasType()->willReturn(false);
        }

        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$param1->isVariadic()->willReturn(false);
        }
        
$param1->isDefaultValueAvailable()->willReturn(false);
        
$param1->isOptional()->willReturn(false);
        
$param1->isPassedByReference()->willReturn(false);
        
$param1->allowsNull()->willReturn(true);
        if (
defined('HHVM_VERSION')) {
            
$param1->getTypehintText()->willReturn(null);
        }

        
$classNode   $this->reflect($class, array());
        
$methodNodes $classNode->getMethods();
        
$argNodes    $methodNodes['methodWithArgs']->getArguments();

        
$argNodes[0]->isOptional()->shouldReturn(false);
    }

    
/**
     * @param ReflectionClass     $class
     * @param ReflectionMethod    $method
     * @param ReflectionParameter $param1
     * @param ReflectionParameter $param2
     * @param ReflectionParameter $param3
     * @param ReflectionClass     $typeHint
     */
    
function it_marks_passed_by_reference_args_as_passed_by_reference(
        
$class$method$param1$param2$param3$typeHint
    
)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->getName()->willReturn('methodWithArgs');
        
$method->isFinal()->willReturn(false);
        
$method->isProtected()->willReturn(false);
        
$method->isStatic()->willReturn(false);
        
$method->returnsReference()->willReturn(false);
        
$method->getParameters()->willReturn(array($param1$param2$param3));

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method->hasReturnType()->willReturn(false);
        }

        
$param1->getName()->willReturn('arg_1');
        
$param1->isArray()->willReturn(false);
        if (
version_compare(PHP_VERSION'5.4''>=')) {
            
$param1->isCallable()->willReturn(false);
        }
        
$param1->getClass()->willReturn(null);
        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$param1->isVariadic()->willReturn(false);
        }
        
$param1->isDefaultValueAvailable()->willReturn(false);
        
$param1->isOptional()->willReturn(true);
        
$param1->isPassedByReference()->willReturn(true);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$param1->hasType()->willReturn(false);
        }

        
$param1->allowsNull()->willReturn(false);
        if (
defined('HHVM_VERSION')) {
            
$param1->getTypehintText()->willReturn(null);
        }

        
$param2->getName()->willReturn('arg2');
        
$param2->isArray()->willReturn(false);
        
$param2->getClass()->willReturn($typeHint);
        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$param2->isVariadic()->willReturn(false);
        }
        
$param2->isDefaultValueAvailable()->willReturn(false);
        
$param2->isOptional()->willReturn(false);
        
$param2->isPassedByReference()->willReturn(false);

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$param2->hasType()->willReturn(false);
        }

        
$param2->allowsNull()->willReturn(false);
        
$typeHint->getName()->willReturn('ArrayAccess');

        
$param3->getName()->willReturn('arg2');
        
$param3->isArray()->willReturn(false);
        
$param3->getClass()->willReturn($typeHint);
        if (
version_compare(PHP_VERSION'5.6''>=')) {
            
$param3->isVariadic()->willReturn(true);
        } else {
            
$param3->isOptional()->willReturn(true);
            
$param3->isDefaultValueAvailable()->willReturn(false);
        }
        
$param3->isPassedByReference()->willReturn(true);
        
$param3->allowsNull()->willReturn(true);

        
$classNode   $this->reflect($class, array());
        
$methodNodes $classNode->getMethods();
        
$argNodes    $methodNodes['methodWithArgs']->getArguments();

        
$argNodes[0]->isPassedByReference()->shouldReturn(true);
        
$argNodes[1]->isPassedByReference()->shouldReturn(false);
        
$argNodes[2]->isPassedByReference()->shouldReturn(true);
    }

    
/**
     * @param ReflectionClass $class
     */
    
function it_throws_an_exception_if_class_is_final($class)
    {
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(true);
        
$class->getName()->willReturn('Custom\ClassName');

        
$this->shouldThrow('Prophecy\Exception\Doubler\ClassMirrorException')
             ->
duringReflect($class, array());
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method
     */
    
function it_ignores_final_methods($class$method)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->isFinal()->willReturn(true);
        
$method->getName()->willReturn('finalImplementation');

        
$classNode $this->reflect($class, array());
        
$classNode->getMethods()->shouldHaveCount(0);
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method
     */
    
function it_marks_final_methods_as_unextendable($class$method)
    {
        
$class->getName()->willReturn('Custom\ClassName');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->isFinal()->willReturn(true);
        
$method->getName()->willReturn('finalImplementation');

        
$classNode $this->reflect($class, array());
        
$classNode->getUnextendableMethods()->shouldHaveCount(1);
        
$classNode->isExtendable('finalImplementation')->shouldReturn(false);
    }

    
/**
     * @param ReflectionClass $interface
     */
    
function it_throws_an_exception_if_interface_provided_instead_of_class($interface)
    {
        
$interface->isInterface()->willReturn(true);
        
$interface->getName()->willReturn('Custom\ClassName');

        
$this->shouldThrow('Prophecy\Exception\InvalidArgumentException')
             ->
duringReflect($interface, array());
    }

    
/**
     * @param ReflectionClass  $interface1
     * @param ReflectionClass  $interface2
     * @param ReflectionMethod $method1
     * @param ReflectionMethod $method2
     * @param ReflectionMethod $method3
     */
    
function it_reflects_all_interfaces_methods(
        
$interface1$interface2$method1$method2$method3
    
)
    {
        
$interface1->getName()->willReturn('MyInterface1');
        
$interface2->getName()->willReturn('MyInterface2');

        
$interface1->isInterface()->willReturn(true);
        
$interface2->isInterface()->willReturn(true);

        
$interface1->getMethods()->willReturn(array($method1));
        
$interface2->getMethods()->willReturn(array($method2$method3));

        
$method1->getName()->willReturn('getName');
        
$method2->getName()->willReturn('isPublic');
        
$method3->getName()->willReturn('isAbstract');

        
$method1->isProtected()->willReturn(false);
        
$method2->isProtected()->willReturn(false);
        
$method3->isProtected()->willReturn(false);

        
$method1->returnsReference()->willReturn(false);
        
$method2->returnsReference()->willReturn(false);
        
$method3->returnsReference()->willReturn(false);

        
$method1->isStatic()->willReturn(false);
        
$method2->isStatic()->willReturn(false);
        
$method3->isStatic()->willReturn(false);

        
$method1->getParameters()->willReturn(array());
        
$method2->getParameters()->willReturn(array());
        
$method3->getParameters()->willReturn(array());

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method1->hasReturnType()->willReturn(false);
            
$method2->hasReturnType()->willReturn(false);
            
$method3->hasReturnType()->willReturn(false);
        }

        
$classNode $this->reflect(null, array($interface1$interface2));

        
$classNode->shouldBeAnInstanceOf('Prophecy\Doubler\Generator\Node\ClassNode');
        
$classNode->getParentClass()->shouldReturn('stdClass');
        
$classNode->getInterfaces()->shouldReturn(array(
            
'Prophecy\Doubler\Generator\ReflectionInterface''MyInterface2''MyInterface1',
        ));

        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(3);

        
$classNode->hasMethod('getName')->shouldReturn(true);
        
$classNode->hasMethod('isPublic')->shouldReturn(true);
        
$classNode->hasMethod('isAbstract')->shouldReturn(true);
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method1
     * @param ReflectionMethod $method2
     * @param ReflectionMethod $method3
     */
    
function it_ignores_virtually_private_methods($class$method1$method2$method3)
    {
        
$class->getName()->willReturn('SomeClass');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method1$method2$method3));

        
$method1->getName()->willReturn('_getName');
        
$method2->getName()->willReturn('__toString');
        
$method3->getName()->willReturn('isAbstract');

        
$method1->isFinal()->willReturn(false);
        
$method2->isFinal()->willReturn(false);
        
$method3->isFinal()->willReturn(false);

        
$method1->isProtected()->willReturn(false);
        
$method2->isProtected()->willReturn(false);
        
$method3->isProtected()->willReturn(false);

        
$method1->isStatic()->willReturn(false);
        
$method2->isStatic()->willReturn(false);
        
$method3->isStatic()->willReturn(false);

        
$method1->returnsReference()->willReturn(false);
        
$method2->returnsReference()->willReturn(false);
        
$method3->returnsReference()->willReturn(false);

        
$method1->getParameters()->willReturn(array());
        
$method2->getParameters()->willReturn(array());
        
$method3->getParameters()->willReturn(array());

        if (
version_compare(PHP_VERSION'7.0''>=')) {
            
$method1->hasReturnType()->willReturn(false);
            
$method2->hasReturnType()->willReturn(false);
            
$method3->hasReturnType()->willReturn(false);
        }

        
$classNode $this->reflect($class, array());
        
$methodNodes $classNode->getMethods();
        
$methodNodes->shouldHaveCount(2);

        
$classNode->hasMethod('isAbstract')->shouldReturn(true);
    }

    
/**
     * @param ReflectionClass  $class
     * @param ReflectionMethod $method
     */
    
function it_does_not_throw_exception_for_virtually_private_finals($class$method)
    {
        
$class->getName()->willReturn('SomeClass');
        
$class->isInterface()->willReturn(false);
        
$class->isFinal()->willReturn(false);
        
$class->getMethods(ReflectionMethod::IS_ABSTRACT)->willReturn(array());
        
$class->getMethods(ReflectionMethod::IS_PUBLIC)->willReturn(array($method));

        
$method->getName()->willReturn('__toString');
        
$method->isFinal()->willReturn(true);

        
$this->shouldNotThrow()->duringReflect($class, array());
    }

    
/**
     * @param ReflectionClass $class
     */
    
function it_throws_an_exception_if_class_provided_in_interfaces_list($class)
    {
        
$class->getName()->willReturn('MyClass');
        
$class->isInterface()->willReturn(false);

        
$this->shouldThrow('InvalidArgumentException')
             ->
duringReflect(null, array($class));
    }

    function 
it_throws_an_exception_if_not_reflection_provided_as_interface()
    {
        
$this->shouldThrow('InvalidArgumentException')
             ->
duringReflect(null, array(null));
    }

    function 
it_doesnt_fail_to_typehint_nonexistent_FQCN()
    {
        
$classNode $this->reflect(new ReflectionClass('spec\Prophecy\Doubler\Generator\OptionalDepsClass'), array());
        
$method $classNode->getMethod('iHaveAStrangeTypeHintedArg');
        
$arguments $method->getArguments();
        
$arguments[0]->getTypeHint()->shouldBe('I\Simply\Am\Nonexistent');
    }

    function 
it_doesnt_fail_to_typehint_nonexistent_RQCN()
    {
        
$classNode $this->reflect(new ReflectionClass('spec\Prophecy\Doubler\Generator\OptionalDepsClass'), array());
        
$method $classNode->getMethod('iHaveAnEvenStrangerTypeHintedArg');
        
$arguments $method->getArguments();
        
$arguments[0]->getTypeHint()->shouldBe('I\Simply\Am\Not');
    }

    function 
it_doesnt_use_scalar_typehints()
    {
        
$classNode $this->reflect(new ReflectionClass('ReflectionMethod'), array());
        
$method $classNode->getMethod('export');
        
$arguments $method->getArguments();
        
$arguments[0]->getTypeHint()->shouldReturn(null);
        
$arguments[1]->getTypeHint()->shouldReturn(null);
        
$arguments[2]->getTypeHint()->shouldReturn(null);
    }
}

class 
OptionalDepsClass
{
    public function 
iHaveAStrangeTypeHintedArg(\I\Simply\Am\Nonexistent $class)
    {
    }

    public function 
iHaveAnEvenStrangerTypeHintedArg(Simply\Am\Not $class)
    {
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by PinoyWH1Z | C99Shell Github | Generation time: 0.0438 ]--