Files
firefly-iii/tests/Unit/Middleware/IsAdminTest.php

112 lines
3.5 KiB
PHP
Raw Normal View History

2017-12-26 17:33:53 +01:00
<?php
/**
* IsAdminTest.php
2020-02-16 13:59:55 +01:00
* Copyright (c) 2019 james@firefly-iii.org
2017-12-26 17:33:53 +01:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2017-12-26 17:33:53 +01:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
2017-12-26 17:33:53 +01:00
*
* This program is distributed in the hope that it will be useful,
2017-12-26 17:33:53 +01:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
2017-12-26 17:33:53 +01:00
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
2017-12-26 17:33:53 +01:00
*/
declare(strict_types=1);
2018-01-25 20:38:50 +01:00
namespace Tests\Unit\Middleware;
2017-12-26 17:33:53 +01:00
use FireflyIII\Http\Middleware\IsAdmin;
use FireflyIII\Repositories\User\UserRepositoryInterface;
use Log;
use Mockery;
2017-12-26 17:33:53 +01:00
use Route;
use Symfony\Component\HttpFoundation\Response;
use Tests\TestCase;
/**
* Class IsAdminTest
2019-08-17 10:48:28 +02:00
* @SuppressWarnings(PHPMD.CouplingBetweenObjects)
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
* @SuppressWarnings(PHPMD.TooManyPublicMethods)
2017-12-26 17:33:53 +01:00
*/
class IsAdminTest extends TestCase
{
2018-09-02 20:27:26 +02:00
/**
* Set up test
*/
public function setUp(): void
{
parent::setUp();
2019-04-09 20:05:20 +02:00
Log::info(sprintf('Now in %s.', get_class($this)));
2018-09-02 20:27:26 +02:00
Route::middleware(IsAdmin::class)->any(
'/_test/is-admin', function () {
return 'OK';
}
);
2018-09-02 20:27:26 +02:00
}
2017-12-26 17:33:53 +01:00
/**
2018-08-09 20:17:15 +02:00
* @covers \FireflyIII\Http\Middleware\IsAdmin
2017-12-26 17:33:53 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testMiddleware(): void
2017-12-26 17:33:53 +01:00
{
$userRepos = $this->mock(UserRepositoryInterface::class);
2017-12-26 17:33:53 +01:00
$this->withoutExceptionHandling();
$response = $this->get('/_test/is-admin');
$this->assertEquals(Response::HTTP_FOUND, $response->getStatusCode());
$response->assertRedirect(route('login'));
}
/**
2018-08-09 20:17:15 +02:00
* @covers \FireflyIII\Http\Middleware\IsAdmin
2017-12-26 17:33:53 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testMiddlewareAjax(): void
2017-12-26 17:33:53 +01:00
{
$userRepos = $this->mock(UserRepositoryInterface::class);
2017-12-26 17:33:53 +01:00
$server = ['HTTP_X-Requested-With' => 'XMLHttpRequest'];
$this->withoutExceptionHandling();
$response = $this->get('/_test/is-admin', $server);
$this->assertEquals(Response::HTTP_UNAUTHORIZED, $response->getStatusCode());
}
/**
2018-08-09 20:17:15 +02:00
* @covers \FireflyIII\Http\Middleware\IsAdmin
2017-12-26 17:33:53 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testMiddlewareNotOwner(): void
2017-12-26 17:33:53 +01:00
{
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(false);
2017-12-26 17:33:53 +01:00
$this->withoutExceptionHandling();
2017-12-29 09:05:35 +01:00
$this->be($this->emptyUser());
2017-12-26 17:33:53 +01:00
$response = $this->get('/_test/is-admin');
2017-12-29 09:05:35 +01:00
$this->assertEquals(Response::HTTP_FOUND, $response->getStatusCode());
$response->assertRedirect(route('home'));
2017-12-26 17:33:53 +01:00
}
/**
2018-08-09 20:17:15 +02:00
* @covers \FireflyIII\Http\Middleware\IsAdmin
2017-12-26 17:33:53 +01:00
*/
2018-05-11 19:58:10 +02:00
public function testMiddlewareOwner(): void
2017-12-26 17:33:53 +01:00
{
$userRepos = $this->mock(UserRepositoryInterface::class);
$userRepos->shouldReceive('hasRole')->withArgs([Mockery::any(), 'owner'])->atLeast()->once()->andReturn(true);
2017-12-29 09:05:35 +01:00
$this->be($this->user());
2017-12-26 17:33:53 +01:00
$this->withoutExceptionHandling();
$response = $this->get('/_test/is-admin');
2017-12-29 09:05:35 +01:00
$this->assertEquals(Response::HTTP_OK, $response->getStatusCode());
2017-12-26 17:33:53 +01:00
}
2018-03-04 15:14:29 +01:00
}