class MethodNodeSpec in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/phpspec/prophecy/spec/Prophecy/Doubler/Generator/Node/MethodNodeSpec.php \spec\Prophecy\Doubler\Generator\Node\MethodNodeSpec
Hierarchy
- class \spec\Prophecy\Doubler\Generator\Node\MethodNodeSpec extends \PhpSpec\ObjectBehavior
Expanded class hierarchy of MethodNodeSpec
File
- vendor/phpspec/ prophecy/ spec/ Prophecy/ Doubler/ Generator/ Node/ MethodNodeSpec.php, line 7 
Namespace
spec\Prophecy\Doubler\Generator\NodeView source
class MethodNodeSpec extends ObjectBehavior {
  function let() {
    $this
      ->beConstructedWith('getTitle');
  }
  function it_has_a_name() {
    $this
      ->getName()
      ->shouldReturn('getTitle');
  }
  function it_has_public_visibility_by_default() {
    $this
      ->getVisibility()
      ->shouldReturn('public');
  }
  function its_visibility_is_mutable() {
    $this
      ->setVisibility('private');
    $this
      ->getVisibility()
      ->shouldReturn('private');
  }
  function it_is_not_static_by_default() {
    $this
      ->shouldNotBeStatic();
  }
  function it_does_not_return_a_reference_by_default() {
    $this
      ->returnsReference()
      ->shouldReturn(false);
  }
  function it_should_be_settable_as_returning_a_reference_through_setter() {
    $this
      ->setReturnsReference();
    $this
      ->returnsReference()
      ->shouldReturn(true);
  }
  function it_should_be_settable_as_static_through_setter() {
    $this
      ->setStatic();
    $this
      ->shouldBeStatic();
  }
  function it_accepts_only_supported_visibilities() {
    $this
      ->shouldThrow('InvalidArgumentException')
      ->duringSetVisibility('stealth');
  }
  function it_lowercases_visibility_before_setting_it() {
    $this
      ->setVisibility('Public');
    $this
      ->getVisibility()
      ->shouldReturn('public');
  }
  /**
   * @param \Prophecy\Doubler\Generator\Node\ArgumentNode $argument1
   * @param \Prophecy\Doubler\Generator\Node\ArgumentNode $argument2
   */
  function its_useParentCode_causes_method_to_call_parent($argument1, $argument2) {
    $argument1
      ->getName()
      ->willReturn('objectName');
    $argument2
      ->getName()
      ->willReturn('default');
    $this
      ->addArgument($argument1);
    $this
      ->addArgument($argument2);
    $this
      ->useParentCode();
    $this
      ->getCode()
      ->shouldReturn('return parent::getTitle($objectName, $default);');
  }
  function its_code_is_mutable() {
    $this
      ->setCode('echo "code";');
    $this
      ->getCode()
      ->shouldReturn('echo "code";');
  }
  function its_reference_returning_methods_will_generate_exceptions() {
    $this
      ->setCode('echo "code";');
    $this
      ->setReturnsReference();
    $this
      ->getCode()
      ->shouldReturn("throw new \\Prophecy\\Exception\\Doubler\\ReturnByReferenceException('Returning by reference not supported', get_class(\$this), 'getTitle');");
  }
  function its_setCode_provided_with_null_cleans_method_body() {
    $this
      ->setCode(null);
    $this
      ->getCode()
      ->shouldReturn('');
  }
  function it_is_constructable_with_code() {
    $this
      ->beConstructedWith('getTitle', 'die();');
    $this
      ->getCode()
      ->shouldReturn('die();');
  }
  function it_does_not_have_arguments_by_default() {
    $this
      ->getArguments()
      ->shouldHaveCount(0);
  }
  /**
   * @param \Prophecy\Doubler\Generator\Node\ArgumentNode $argument1
   * @param \Prophecy\Doubler\Generator\Node\ArgumentNode $argument2
   */
  function it_supports_adding_arguments($argument1, $argument2) {
    $this
      ->addArgument($argument1);
    $this
      ->addArgument($argument2);
    $this
      ->getArguments()
      ->shouldReturn(array(
      $argument1,
      $argument2,
    ));
  }
  function it_does_not_have_return_type_by_default() {
    $this
      ->hasReturnType()
      ->shouldReturn(false);
  }
  function it_setReturnType_sets_return_type() {
    $returnType = 'string';
    $this
      ->setReturnType($returnType);
    $this
      ->hasReturnType()
      ->shouldReturn(true);
    $this
      ->getReturnType()
      ->shouldReturn($returnType);
  }
} 
      