forked from GNUsocial/gnu-social
[TESTS] Raise test coverage for Attachment controller to 100%
This commit is contained in:
parent
ed21290ef4
commit
f9c1d14c7a
@ -44,8 +44,11 @@ class Attachment extends Controller
|
||||
*/
|
||||
private function attachment(int $id, callable $handle)
|
||||
{
|
||||
if ($id <= 0) {
|
||||
if ($id <= 0) { // This should never happen coming from the router, but let's bail if it does
|
||||
// @codeCoverageIgnoreStart
|
||||
Log::critical("Attachment controller called with {$id}, which should not be possible");
|
||||
throw new ClientException(_m('No such attachment'), 404);
|
||||
// @codeCoverageIgnoreEnd
|
||||
} else {
|
||||
if (Event::handle('AttachmentFileInfo', [$id, &$res]) != Event::stop) {
|
||||
// If no one else claims this attachment, use the default representation
|
||||
@ -56,7 +59,9 @@ class Attachment extends Controller
|
||||
if (!empty($res)) {
|
||||
return $handle($res);
|
||||
} else {
|
||||
// @codeCoverageIgnoreStart
|
||||
throw new ClientException(_m('No such attachment'), 404);
|
||||
// @codeCoverageIgnoreEnd
|
||||
}
|
||||
}
|
||||
|
||||
@ -112,9 +117,11 @@ class Attachment extends Controller
|
||||
$attachment = DB::findOneBy('attachment', ['id' => $id]);
|
||||
|
||||
if (!is_null($attachment->getScope())) {
|
||||
// @codeCoverageIgnoreStart
|
||||
// && ($attachment->scope | VisibilityScope::PUBLIC) != 0
|
||||
// $user = Common::ensureLoggedIn();
|
||||
assert(false, 'Attachment scope not implemented');
|
||||
// @codeCoverageIgnoreEnd
|
||||
}
|
||||
|
||||
$default_width = Common::config('thumbnail', 'width');
|
||||
|
84
tests/Controller/AttachmentTest.php
Normal file
84
tests/Controller/AttachmentTest.php
Normal file
@ -0,0 +1,84 @@
|
||||
<?php
|
||||
|
||||
// {{{ License
|
||||
|
||||
// This file is part of GNU social - https://www.gnu.org/software/social
|
||||
//
|
||||
// GNU social 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.
|
||||
//
|
||||
// GNU social is distributed in the hope that it will be useful,
|
||||
// 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.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with GNU social. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
// }}}
|
||||
|
||||
namespace App\Tests\Core;
|
||||
|
||||
use App\Core\DB\DB;
|
||||
use App\Util\GNUsocialTestCase;
|
||||
|
||||
class AttachmentTest extends GNUsocialTestCase
|
||||
{
|
||||
public function testNoAttachmentID()
|
||||
{
|
||||
// This calls static::bootKernel(), and creates a "client" that is acting as the browser
|
||||
$client = static::createClient();
|
||||
$client->request('GET', '/attachment');
|
||||
$this->assertResponseStatusCodeSame(404);
|
||||
$client->request('GET', '/attachment/-1');
|
||||
$this->assertResponseStatusCodeSame(404);
|
||||
$client->request('GET', '/attachment/asd');
|
||||
$this->assertResponseStatusCodeSame(404);
|
||||
$client->request('GET', '/attachment/0');
|
||||
// In the meantime, throwing ClientException doesn't actually result in the reaching the UI, as it's intercepted
|
||||
// by the helpful framework that displays the stack traces and such. This should be easily fixable when we have
|
||||
// our own error pages
|
||||
$this->assertSelectorTextContains('.stacktrace', 'ClientException');
|
||||
}
|
||||
|
||||
private function testAttachment(string $suffix)
|
||||
{
|
||||
$client = static::createClient();
|
||||
$attachment = DB::findOneBy('attachment', ['title' => '1x1 JPEG image title']);
|
||||
$crawler = $client->request('GET', "/attachment/{$attachment->getId()}{$suffix}");
|
||||
}
|
||||
|
||||
public function testAttachmentShow()
|
||||
{
|
||||
$this->testAttachment('');
|
||||
$this->assertResponseIsSuccessful();
|
||||
$this->assertSelectorTextContains('figure figcaption', '1x1 JPEG image title');
|
||||
}
|
||||
|
||||
public function testAttachmentView()
|
||||
{
|
||||
$this->testAttachment('/view');
|
||||
$this->assertResponseIsSuccessful();
|
||||
}
|
||||
|
||||
public function testAttachmentDownload()
|
||||
{
|
||||
$this->testAttachment('/download');
|
||||
$this->assertResponseIsSuccessful();
|
||||
}
|
||||
|
||||
public function testAttachmentThumbnail()
|
||||
{
|
||||
$this->testAttachment('/thumbnail');
|
||||
$this->assertResponseIsSuccessful();
|
||||
}
|
||||
|
||||
public function testAttachmentThumbnailWrongSize()
|
||||
{
|
||||
$this->testAttachment('/thumbnail?w=1&h=1');
|
||||
$this->assertSelectorTextContains('.stacktrace', 'ClientException');
|
||||
// $this->assertResponseStatusCodeSame(400);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user