1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
<?php
namespace Illuminate\Tests\Session;
use Illuminate\Contracts\Encryption\Encrypter;
use Illuminate\Session\EncryptedStore;
use Mockery as m;
use PHPUnit\Framework\TestCase;
use ReflectionClass;
use SessionHandlerInterface;
class EncryptedSessionStoreTest extends TestCase
{
protected function tearDown(): void
{
m::close();
}
public function testSessionIsProperlyEncrypted()
{
$session = $this->getSession();
$session->getEncrypter()->shouldReceive('decrypt')->once()->with(serialize([]))->andReturn(serialize([]));
$session->getHandler()->shouldReceive('read')->once()->andReturn(serialize([]));
$session->start();
$session->put('foo', 'bar');
$session->flash('baz', 'boom');
$session->now('qux', 'norf');
$serialized = serialize([
'_token' => $session->token(),
'foo' => 'bar',
'baz' => 'boom',
'_flash' => [
'new' => [],
'old' => ['baz'],
],
]);
$session->getEncrypter()->shouldReceive('encrypt')->once()->with($serialized)->andReturn($serialized);
$session->getHandler()->shouldReceive('write')->once()->with(
$this->getSessionId(),
$serialized
);
$session->save();
$this->assertFalse($session->isStarted());
}
public function getSession()
{
$reflection = new ReflectionClass(EncryptedStore::class);
return $reflection->newInstanceArgs($this->getMocks());
}
public function getMocks()
{
return [
$this->getSessionName(),
m::mock(SessionHandlerInterface::class),
m::mock(Encrypter::class),
$this->getSessionId(),
];
}
public function getSessionId()
{
return 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa';
}
public function getSessionName()
{
return 'name';
}
}
|