summaryrefslogtreecommitdiff
path: root/tests/Unit/Http
diff options
context:
space:
mode:
authorIgor Scheller <igor.scheller@igorshp.de>2018-09-30 19:31:14 +0200
committerIgor Scheller <igor.scheller@igorshp.de>2018-09-30 19:33:14 +0200
commitb46207f91176cf944284c01c213d3f69075377a4 (patch)
tree3d04a46c84c8b66b2d5a56a851249fde80257e28 /tests/Unit/Http
parent6187eed3bb08f200050a3078bd762b5731dfbe78 (diff)
parent0b0890f425ced27b2204a046296de4cccdac4eb8 (diff)
Merge remote-tracking branch 'MyIgel/session'
Diffstat (limited to 'tests/Unit/Http')
-rw-r--r--tests/Unit/Http/SessionHandlers/AbstractHandlerTest.php44
-rw-r--r--tests/Unit/Http/SessionHandlers/DatabaseHandlerTest.php95
-rw-r--r--tests/Unit/Http/SessionHandlers/Stub/ArrayHandler.php59
-rw-r--r--tests/Unit/Http/SessionServiceProviderTest.php56
4 files changed, 249 insertions, 5 deletions
diff --git a/tests/Unit/Http/SessionHandlers/AbstractHandlerTest.php b/tests/Unit/Http/SessionHandlers/AbstractHandlerTest.php
new file mode 100644
index 00000000..bfd2e883
--- /dev/null
+++ b/tests/Unit/Http/SessionHandlers/AbstractHandlerTest.php
@@ -0,0 +1,44 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Http\SessionHandlers;
+
+use Engelsystem\Test\Unit\Http\SessionHandlers\Stub\ArrayHandler;
+use PHPUnit\Framework\TestCase;
+
+class AbstractHandlerTest extends TestCase
+{
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\AbstractHandler::open
+ */
+ public function testOpen()
+ {
+ $handler = new ArrayHandler();
+ $return = $handler->open('/foo/bar', '1337asd098hkl7654');
+
+ $this->assertTrue($return);
+ $this->assertEquals('1337asd098hkl7654', $handler->getName());
+ $this->assertEquals('/foo/bar', $handler->getSessionPath());
+ }
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\AbstractHandler::close
+ */
+ public function testClose()
+ {
+ $handler = new ArrayHandler();
+ $return = $handler->close();
+
+ $this->assertTrue($return);
+ }
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\AbstractHandler::gc
+ */
+ public function testGc()
+ {
+ $handler = new ArrayHandler();
+ $return = $handler->gc(60 * 60 * 24);
+
+ $this->assertTrue($return);
+ }
+}
diff --git a/tests/Unit/Http/SessionHandlers/DatabaseHandlerTest.php b/tests/Unit/Http/SessionHandlers/DatabaseHandlerTest.php
new file mode 100644
index 00000000..ea4f3701
--- /dev/null
+++ b/tests/Unit/Http/SessionHandlers/DatabaseHandlerTest.php
@@ -0,0 +1,95 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Http\SessionHandlers;
+
+use Engelsystem\Http\SessionHandlers\DatabaseHandler;
+use Engelsystem\Test\Unit\HasDatabase;
+use PHPUnit\Framework\TestCase;
+
+class DatabaseHandlerTest extends TestCase
+{
+ use HasDatabase;
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::__construct
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::read
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::getQuery
+ */
+ public function testRead()
+ {
+ $handler = new DatabaseHandler($this->database);
+ $this->assertEquals('', $handler->read('foo'));
+
+ $this->database->insert("INSERT INTO sessions VALUES ('foo', 'Lorem Ipsum', CURRENT_TIMESTAMP)");
+ $this->assertEquals('Lorem Ipsum', $handler->read('foo'));
+ }
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::write
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::getCurrentTimestamp
+ */
+ public function testWrite()
+ {
+ $handler = new DatabaseHandler($this->database);
+
+ foreach (['Lorem Ipsum', 'Dolor Sit!'] as $data) {
+ $this->assertTrue($handler->write('foo', $data));
+
+ $return = $this->database->select('SELECT * FROM sessions WHERE id = :id', ['id' => 'foo']);
+ $this->assertCount(1, $return);
+
+ $return = array_shift($return);
+ $this->assertEquals($data, $return->payload);
+ }
+ }
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::destroy
+ */
+ public function testDestroy()
+ {
+ $this->database->insert("INSERT INTO sessions VALUES ('foo', 'Lorem Ipsum', CURRENT_TIMESTAMP)");
+ $this->database->insert("INSERT INTO sessions VALUES ('bar', 'Dolor Sit', CURRENT_TIMESTAMP)");
+
+ $handler = new DatabaseHandler($this->database);
+ $this->assertTrue($handler->destroy('batz'));
+
+ $return = $this->database->select('SELECT * FROM sessions');
+ $this->assertCount(2, $return);
+
+ $this->assertTrue($handler->destroy('bar'));
+
+ $return = $this->database->select('SELECT * FROM sessions');
+ $this->assertCount(1, $return);
+
+ $return = array_shift($return);
+ $this->assertEquals('foo', $return->id);
+ }
+
+ /**
+ * @covers \Engelsystem\Http\SessionHandlers\DatabaseHandler::gc
+ */
+ public function testGc()
+ {
+ $this->database->insert("INSERT INTO sessions VALUES ('foo', 'Lorem Ipsum', '2000-01-01 01:00')");
+ $this->database->insert("INSERT INTO sessions VALUES ('bar', 'Dolor Sit', '3000-01-01 01:00')");
+
+ $handler = new DatabaseHandler($this->database);
+
+ $this->assertTrue($handler->gc(60 * 60));
+
+ $return = $this->database->select('SELECT * FROM sessions');
+ $this->assertCount(1, $return);
+
+ $return = array_shift($return);
+ $this->assertEquals('bar', $return->id);
+ }
+
+ /**
+ * Prepare tests
+ */
+ protected function setUp()
+ {
+ $this->initDatabase();
+ }
+}
diff --git a/tests/Unit/Http/SessionHandlers/Stub/ArrayHandler.php b/tests/Unit/Http/SessionHandlers/Stub/ArrayHandler.php
new file mode 100644
index 00000000..4d37da48
--- /dev/null
+++ b/tests/Unit/Http/SessionHandlers/Stub/ArrayHandler.php
@@ -0,0 +1,59 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Http\SessionHandlers\Stub;
+
+use Engelsystem\Http\SessionHandlers\AbstractHandler;
+
+class ArrayHandler extends AbstractHandler
+{
+ /** @var string[] */
+ protected $content = [];
+
+ /**
+ * {@inheritdoc}
+ */
+ public function read($id): string
+ {
+ if (isset($this->content[$id])) {
+ return $this->content[$id];
+ }
+
+ return '';
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write($id, $data): bool
+ {
+ $this->content[$id] = $data;
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function destroy($id): bool
+ {
+ unset($this->content[$id]);
+
+ return true;
+ }
+
+ /**
+ * @return string
+ */
+ public function getName(): string
+ {
+ return $this->name;
+ }
+
+ /**
+ * @return string
+ */
+ public function getSessionPath(): string
+ {
+ return $this->sessionPath;
+ }
+}
diff --git a/tests/Unit/Http/SessionServiceProviderTest.php b/tests/Unit/Http/SessionServiceProviderTest.php
index d0125bc2..dd0e538f 100644
--- a/tests/Unit/Http/SessionServiceProviderTest.php
+++ b/tests/Unit/Http/SessionServiceProviderTest.php
@@ -2,7 +2,9 @@
namespace Engelsystem\Test\Unit\Http;
+use Engelsystem\Config\Config;
use Engelsystem\Http\Request;
+use Engelsystem\Http\SessionHandlers\DatabaseHandler;
use Engelsystem\Http\SessionServiceProvider;
use Engelsystem\Test\Unit\ServiceProviderTest;
use PHPUnit_Framework_MockObject_MockObject as MockObject;
@@ -23,6 +25,9 @@ class SessionServiceProviderTest extends ServiceProviderTest
$sessionStorage = $this->getMockForAbstractClass(StorageInterface::class);
$sessionStorage2 = $this->getMockForAbstractClass(StorageInterface::class);
+ $databaseHandler = $this->getMockBuilder(DatabaseHandler::class)
+ ->disableOriginalConstructor()
+ ->getMock();
$session = $this->getSessionMock();
$request = $this->getRequestMock();
@@ -32,22 +37,38 @@ class SessionServiceProviderTest extends ServiceProviderTest
->setConstructorArgs([$app])
->setMethods(['isCli'])
->getMock();
- $serviceProvider->expects($this->exactly(2))
+
+ /** @var Config|MockObject $config */
+ $config = $this->createMock(Config::class);
+
+ $serviceProvider->expects($this->exactly(3))
->method('isCli')
- ->willReturnOnConsecutiveCalls(true, false);
+ ->willReturnOnConsecutiveCalls(true, false, false);
- $app->expects($this->exactly(4))
+ $app->expects($this->exactly(7))
->method('make')
->withConsecutive(
[MockArraySessionStorage::class],
[Session::class],
- [NativeSessionStorage::class, ['options' => ['cookie_httponly' => true]]],
+ [
+ NativeSessionStorage::class,
+ ['options' => ['cookie_httponly' => true, 'name' => 'session'], 'handler' => null]
+ ],
+ [Session::class],
+ [DatabaseHandler::class],
+ [
+ NativeSessionStorage::class,
+ ['options' => ['cookie_httponly' => true, 'name' => 'foobar'], 'handler' => $databaseHandler]
+ ],
[Session::class]
)
->willReturnOnConsecutiveCalls(
$sessionStorage,
$session,
$sessionStorage2,
+ $session,
+ $databaseHandler,
+ $sessionStorage2,
$session
);
$app->expects($this->atLeastOnce())
@@ -58,13 +79,38 @@ class SessionServiceProviderTest extends ServiceProviderTest
['session', $session]
);
+ $app->expects($this->exactly(5))
+ ->method('get')
+ ->withConsecutive(
+ ['request'],
+ ['config'],
+ ['request'],
+ ['config'],
+ ['request']
+ )
+ ->willReturnOnConsecutiveCalls(
+ $request,
+ $config,
+ $request,
+ $config,
+ $request
+ );
+
+ $config->expects($this->exactly(2))
+ ->method('get')
+ ->with('session')
+ ->willReturnOnConsecutiveCalls(
+ ['driver' => 'native', 'name' => 'session'],
+ ['driver' => 'pdo', 'name' => 'foobar']
+ );
+
$this->setExpects($app, 'bind', [StorageInterface::class, 'session.storage'], null, $this->atLeastOnce());
- $this->setExpects($app, 'get', ['request'], $request, $this->atLeastOnce());
$this->setExpects($request, 'setSession', [$session], null, $this->atLeastOnce());
$this->setExpects($session, 'start', null, null, $this->atLeastOnce());
$serviceProvider->register();
$serviceProvider->register();
+ $serviceProvider->register();
}
/**