Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php namespace Illuminate\Tests\Support; use ArrayAccess; use Illuminate\Support\Facade..
Decoded Output download
<?php
namespace Illuminate\Tests\Support;
use ArrayAccess;
use Illuminate\Support\Facades\Facade;
use Mockery as m;
use Mockery\MockInterface;
use PHPUnit\Framework\TestCase;
use stdClass;
class SupportFacadeTest extends TestCase
{
protected function setUp(): void
{
Facade::clearResolvedInstances();
FacadeStub::setFacadeApplication(null);
}
protected function tearDown(): void
{
m::close();
}
public function testFacadeCallsUnderlyingApplication()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => $mock = m::mock(stdClass::class)]);
$mock->shouldReceive('bar')->once()->andReturn('baz');
FacadeStub::setFacadeApplication($app);
$this->assertSame('baz', FacadeStub::bar());
}
public function testShouldReceiveReturnsAMockeryMock()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo')->once()->with('bar')->andReturn('baz')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
}
public function testSpyReturnsAMockerySpy()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $spy = FacadeStub::spy());
FacadeStub::foo();
$spy->shouldHaveReceived('foo');
}
public function testShouldReceiveCanBeCalledTwice()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo')->once()->with('bar')->andReturn('baz')->getMock());
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo2')->once()->with('bar2')->andReturn('baz2')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
$this->assertSame('baz2', $app['foo']->foo2('bar2'));
}
public function testCanBeMockedWithoutUnderlyingInstance()
{
FacadeStub::shouldReceive('foo')->once()->andReturn('bar');
$this->assertSame('bar', FacadeStub::foo());
}
public function testExpectsReturnsAMockeryMockWithExpectationRequired()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::expects('foo')->with('bar')->andReturn('baz')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
}
}
class FacadeStub extends Facade
{
protected static function getFacadeAccessor()
{
return 'foo';
}
}
class ApplicationStub implements ArrayAccess
{
protected $attributes = [];
public function setAttributes($attributes)
{
$this->attributes = $attributes;
}
public function instance($key, $instance)
{
$this->attributes[$key] = $instance;
}
public function offsetExists($offset): bool
{
return isset($this->attributes[$offset]);
}
public function offsetGet($key): mixed
{
return $this->attributes[$key];
}
public function offsetSet($key, $value): void
{
$this->attributes[$key] = $value;
}
public function offsetUnset($key): void
{
unset($this->attributes[$key]);
}
}
?>
Did this file decode correctly?
Original Code
<?php
namespace Illuminate\Tests\Support;
use ArrayAccess;
use Illuminate\Support\Facades\Facade;
use Mockery as m;
use Mockery\MockInterface;
use PHPUnit\Framework\TestCase;
use stdClass;
class SupportFacadeTest extends TestCase
{
protected function setUp(): void
{
Facade::clearResolvedInstances();
FacadeStub::setFacadeApplication(null);
}
protected function tearDown(): void
{
m::close();
}
public function testFacadeCallsUnderlyingApplication()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => $mock = m::mock(stdClass::class)]);
$mock->shouldReceive('bar')->once()->andReturn('baz');
FacadeStub::setFacadeApplication($app);
$this->assertSame('baz', FacadeStub::bar());
}
public function testShouldReceiveReturnsAMockeryMock()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo')->once()->with('bar')->andReturn('baz')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
}
public function testSpyReturnsAMockerySpy()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $spy = FacadeStub::spy());
FacadeStub::foo();
$spy->shouldHaveReceived('foo');
}
public function testShouldReceiveCanBeCalledTwice()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo')->once()->with('bar')->andReturn('baz')->getMock());
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::shouldReceive('foo2')->once()->with('bar2')->andReturn('baz2')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
$this->assertSame('baz2', $app['foo']->foo2('bar2'));
}
public function testCanBeMockedWithoutUnderlyingInstance()
{
FacadeStub::shouldReceive('foo')->once()->andReturn('bar');
$this->assertSame('bar', FacadeStub::foo());
}
public function testExpectsReturnsAMockeryMockWithExpectationRequired()
{
$app = new ApplicationStub;
$app->setAttributes(['foo' => new stdClass]);
FacadeStub::setFacadeApplication($app);
$this->assertInstanceOf(MockInterface::class, $mock = FacadeStub::expects('foo')->with('bar')->andReturn('baz')->getMock());
$this->assertSame('baz', $app['foo']->foo('bar'));
}
}
class FacadeStub extends Facade
{
protected static function getFacadeAccessor()
{
return 'foo';
}
}
class ApplicationStub implements ArrayAccess
{
protected $attributes = [];
public function setAttributes($attributes)
{
$this->attributes = $attributes;
}
public function instance($key, $instance)
{
$this->attributes[$key] = $instance;
}
public function offsetExists($offset): bool
{
return isset($this->attributes[$offset]);
}
public function offsetGet($key): mixed
{
return $this->attributes[$key];
}
public function offsetSet($key, $value): void
{
$this->attributes[$key] = $value;
}
public function offsetUnset($key): void
{
unset($this->attributes[$key]);
}
}
Function Calls
| None |
Stats
| MD5 | fd05deb442dfdda9e71045e85d3d5f8e |
| Eval Count | 0 |
| Decode Time | 108 ms |