Mercurial > hg > isophonics-drupal-site
diff vendor/phpunit/phpunit-mock-objects/tests/MockObject/232.phpt @ 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/phpunit/phpunit-mock-objects/tests/MockObject/232.phpt Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,129 @@ +--TEST-- +PHPUnit_Framework_MockObject_Generator::generate('Foo', array(), 'MockFoo', TRUE, TRUE) +--SKIPIF-- +<?php +if (version_compare(PHP_VERSION, '5.4.0', '<')) print 'skip: PHP >= 5.4.0 required'; +?> +--FILE-- +<?php +trait BaseTrait +{ + protected function hello() + { + return 'hello'; + } +} + +trait ChildTrait +{ + use BaseTrait + { + hello as private hi; + } + + protected function hello() + { + return 'hi'; + } + + protected function world() + { + return $this->hi(); + } +} + +class Foo +{ + use ChildTrait; + + public function speak() + { + return $this->world(); + } +} + +require __DIR__ . '/../../vendor/autoload.php'; + +$generator = new PHPUnit_Framework_MockObject_Generator; + +$mock = $generator->generate( + 'Foo', + array(), + 'MockFoo', + TRUE, + TRUE +); + +print $mock['code']; +?> +--EXPECTF-- +class MockFoo extends Foo implements PHPUnit_Framework_MockObject_MockObject +{ + private $__phpunit_invocationMocker; + private $__phpunit_originalObject; + + public function __clone() + { + $this->__phpunit_invocationMocker = clone $this->__phpunit_getInvocationMocker(); + } + + public function speak() + { + $arguments = array(); + $count = func_num_args(); + + if ($count > 0) { + $_arguments = func_get_args(); + + for ($i = 0; $i < $count; $i++) { + $arguments[] = $_arguments[$i]; + } + } + + $result = $this->__phpunit_getInvocationMocker()->invoke( + new PHPUnit_Framework_MockObject_Invocation_Object( + 'Foo', 'speak', $arguments, $this, TRUE + ) + ); + + return $result; + } + + public function expects(PHPUnit_Framework_MockObject_Matcher_Invocation $matcher) + { + return $this->__phpunit_getInvocationMocker()->expects($matcher); + } + + public function method() + { + $any = new PHPUnit_Framework_MockObject_Matcher_AnyInvokedCount; + $expects = $this->expects($any); + return call_user_func_array(array($expects, 'method'), func_get_args()); + } + + public function __phpunit_setOriginalObject($originalObject) + { + $this->__phpunit_originalObject = $originalObject; + } + + public function __phpunit_getInvocationMocker() + { + if ($this->__phpunit_invocationMocker === NULL) { + $this->__phpunit_invocationMocker = new PHPUnit_Framework_MockObject_InvocationMocker; + } + + return $this->__phpunit_invocationMocker; + } + + public function __phpunit_hasMatchers() + { + return $this->__phpunit_getInvocationMocker()->hasMatchers(); + } + + public function __phpunit_verify() + { + $this->__phpunit_getInvocationMocker()->verify(); + $this->__phpunit_invocationMocker = NULL; + } +} +