mirror of
https://github.com/flarum/framework.git
synced 2024-12-12 22:53:37 +08:00
cf746079ed
This creates a dedicated test suite for integration tests. All of them can be run independently, and there is no order dependency - previously, all integration tests needed the installer test to run first, and they would fail if installation failed. Now, the developer will have to set up a Flarum database to be used by these tests. A setup script to make this simple will be added in the next commit. Small tradeoff: the installer is NOT tested in our test suite anymore, only implicitly through the setup script. If we decide that this is a problem, we can still set up separate, dedicated installer tests which should probably test the web installer.
61 lines
1.5 KiB
PHP
61 lines
1.5 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Flarum.
|
|
*
|
|
* (c) Toby Zerner <toby.zerner@gmail.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Flarum\Tests\integration\api\Controller;
|
|
|
|
use Flarum\Api\Client;
|
|
use Flarum\Tests\integration\RetrievesAuthorizedUsers;
|
|
use Flarum\Tests\integration\TestCase;
|
|
use Flarum\User\Guest;
|
|
use Flarum\User\User;
|
|
use Illuminate\Support\Arr;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use Psr\Http\Server\RequestHandlerInterface;
|
|
|
|
abstract class ApiControllerTestCase extends TestCase
|
|
{
|
|
use RetrievesAuthorizedUsers;
|
|
|
|
/**
|
|
* @var RequestHandlerInterface
|
|
*/
|
|
protected $controller;
|
|
|
|
/**
|
|
* @var null|User
|
|
*/
|
|
protected $actor = null;
|
|
|
|
protected function callWith(array $body = [], array $queryParams = []): ResponseInterface
|
|
{
|
|
if (! Arr::get($body, 'data') && Arr::isAssoc($body)) {
|
|
$body = ['data' => ['attributes' => $body]];
|
|
}
|
|
|
|
return $this->call(
|
|
$this->controller,
|
|
$this->actor,
|
|
$queryParams,
|
|
$body
|
|
);
|
|
}
|
|
|
|
public function call(string $controller, User $actor = null, array $queryParams = [], array $body = []): ResponseInterface
|
|
{
|
|
/** @var Client $api */
|
|
$api = $this->app()->getContainer()->make(Client::class);
|
|
|
|
$api->setErrorHandler(null);
|
|
|
|
return $api->send($controller, $actor ?? new Guest, $queryParams, $body);
|
|
}
|
|
}
|