summaryrefslogtreecommitdiff
path: root/tests/Unit/Http
diff options
context:
space:
mode:
Diffstat (limited to 'tests/Unit/Http')
-rw-r--r--tests/Unit/Http/RedirectServiceProviderTest.php23
-rw-r--r--tests/Unit/Http/RedirectorTest.php53
-rw-r--r--tests/Unit/Http/ResponseTest.php57
3 files changed, 133 insertions, 0 deletions
diff --git a/tests/Unit/Http/RedirectServiceProviderTest.php b/tests/Unit/Http/RedirectServiceProviderTest.php
new file mode 100644
index 00000000..9c2a07fc
--- /dev/null
+++ b/tests/Unit/Http/RedirectServiceProviderTest.php
@@ -0,0 +1,23 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Http;
+
+use Engelsystem\Application;
+use Engelsystem\Http\RedirectServiceProvider;
+use Engelsystem\Test\Unit\ServiceProviderTest;
+
+class RedirectServiceProviderTest extends ServiceProviderTest
+{
+ /**
+ * @covers \Engelsystem\Http\RedirectServiceProvider::register
+ */
+ public function testRegister()
+ {
+ $app = new Application();
+
+ $serviceProvider = new RedirectServiceProvider($app);
+ $serviceProvider->register();
+
+ $this->assertTrue($app->has('redirect'));
+ }
+}
diff --git a/tests/Unit/Http/RedirectorTest.php b/tests/Unit/Http/RedirectorTest.php
new file mode 100644
index 00000000..300b0180
--- /dev/null
+++ b/tests/Unit/Http/RedirectorTest.php
@@ -0,0 +1,53 @@
+<?php
+
+namespace Engelsystem\Test\Unit\Http;
+
+use Engelsystem\Http\Redirector;
+use Engelsystem\Http\Request;
+use Engelsystem\Http\Response;
+use PHPUnit\Framework\TestCase;
+
+class RedirectorTest extends TestCase
+{
+ /**
+ * @covers \Engelsystem\Http\Redirector::__construct
+ * @covers \Engelsystem\Http\Redirector::to
+ */
+ public function testTo()
+ {
+ $request = new Request();
+ $response = new Response();
+ $redirector = new Redirector($request, $response);
+
+ $return = $redirector->to('/test');
+ $this->assertEquals(['/test'], $return->getHeader('location'));
+ $this->assertEquals(302, $return->getStatusCode());
+
+ $return = $redirector->to('/foo', 303, ['test' => 'data']);
+ $this->assertEquals(['/foo'], $return->getHeader('location'));
+ $this->assertEquals(303, $return->getStatusCode());
+ $this->assertEquals(['data'], $return->getHeader('test'));
+ }
+
+ /**
+ * @covers \Engelsystem\Http\Redirector::back
+ * @covers \Engelsystem\Http\Redirector::getPreviousUrl
+ */
+ public function testBack()
+ {
+ $request = new Request();
+ $response = new Response();
+ $redirector = new Redirector($request, $response);
+
+ $return = $redirector->back();
+ $this->assertEquals(['/'], $return->getHeader('location'));
+ $this->assertEquals(302, $return->getStatusCode());
+
+ $request = $request->withHeader('referer', '/old-page');
+ $redirector = new Redirector($request, $response);
+ $return = $redirector->back(303, ['foo' => 'bar']);
+ $this->assertEquals(303, $return->getStatusCode());
+ $this->assertEquals(['/old-page'], $return->getHeader('location'));
+ $this->assertEquals(['bar'], $return->getHeader('foo'));
+ }
+}
diff --git a/tests/Unit/Http/ResponseTest.php b/tests/Unit/Http/ResponseTest.php
index b8e6e527..56d8410f 100644
--- a/tests/Unit/Http/ResponseTest.php
+++ b/tests/Unit/Http/ResponseTest.php
@@ -10,6 +10,8 @@ use PHPUnit\Framework\MockObject\MockObject;
use PHPUnit\Framework\TestCase;
use Psr\Http\Message\ResponseInterface;
use Symfony\Component\HttpFoundation\Response as SymfonyResponse;
+use Symfony\Component\HttpFoundation\Session\Session;
+use Symfony\Component\HttpFoundation\Session\Storage\MockArraySessionStorage;
class ResponseTest extends TestCase
{
@@ -116,4 +118,59 @@ class ResponseTest extends TestCase
$newResponse->getHeaders()
);
}
+
+ /**
+ * @covers \Engelsystem\Http\Response::with
+ */
+ public function testWith()
+ {
+ $session = new Session(new MockArraySessionStorage());
+ $response = new Response('', 200, [], null, $session);
+
+ $response->with('foo', 'bar');
+ $this->assertEquals('bar', $session->get('foo'));
+
+ $response->with('lorem', ['ipsum', 'dolor' => ['foo' => 'bar']]);
+ $this->assertEquals(['ipsum', 'dolor' => ['foo' => 'bar']], $session->get('lorem'));
+
+ $response->with('lorem', ['dolor' => ['test' => 'er']]);
+ $this->assertEquals(['ipsum', 'dolor' => ['foo' => 'bar', 'test' => 'er']], $session->get('lorem'));
+ }
+
+ /**
+ * @covers \Engelsystem\Http\Response::with
+ */
+ public function testWithNoSession()
+ {
+ $this->expectException(InvalidArgumentException::class);
+
+ $response = new Response();
+ $response->with('foo', 'bar');
+ }
+
+ /**
+ * @covers \Engelsystem\Http\Response::withInput
+ */
+ public function testWithInput()
+ {
+ $session = new Session(new MockArraySessionStorage());
+ $response = new Response('', 200, [], null, $session);
+
+ $response->withInput(['some' => 'value']);
+ $this->assertEquals(['some' => 'value'], $session->get('form-data'));
+
+ $response->withInput(['lorem' => 'ipsum']);
+ $this->assertEquals(['lorem' => 'ipsum'], $session->get('form-data'));
+ }
+
+ /**
+ * @covers \Engelsystem\Http\Response::withInput
+ */
+ public function testWithInputNoSession()
+ {
+ $this->expectException(InvalidArgumentException::class);
+
+ $response = new Response();
+ $response->withInput(['some' => 'value']);
+ }
}