mirror of
https://github.com/flarum/framework.git
synced 2025-01-11 13:58:33 +08:00
84ded0ce50
- update actions ci - include json for 4 spaces tab - provide output int for process code exit - adhere to parent type hint of builder - mailer instance now needs a name, multiple can be instantiated - getOriginal now uses mutators in the model - Temporarily loosen MailableInterface requirements. This avoids an immediate BC break for classes in extensions that implement this interface. - Temporarily provide (and autoload) old symfony translator interface - make queue exception handler compatible with the contract of L8 - Update phpunit schema for newer version - Update phpunit assert calls for newer version
103 lines
3.2 KiB
PHP
103 lines
3.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Flarum.
|
|
*
|
|
* For detailed copyright and license information, please view the
|
|
* LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Flarum\Tests\unit\User;
|
|
|
|
use Flarum\Tests\unit\TestCase;
|
|
use Flarum\User\AvatarUploader;
|
|
use Flarum\User\User;
|
|
use Illuminate\Contracts\Events\Dispatcher;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Intervention\Image\ImageManagerStatic;
|
|
use League\Flysystem\FilesystemInterface;
|
|
use Mockery as m;
|
|
|
|
class AvatarUploaderTest extends TestCase
|
|
{
|
|
private $dispatcher;
|
|
private $filesystem;
|
|
private $uploader;
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
protected function setUp(): void
|
|
{
|
|
$this->dispatcher = m::mock(Dispatcher::class);
|
|
$this->dispatcher->shouldIgnoreMissing();
|
|
Model::setEventDispatcher($this->dispatcher);
|
|
|
|
$this->filesystem = m::mock(FilesystemInterface::class);
|
|
$this->uploader = new AvatarUploader($this->filesystem);
|
|
}
|
|
|
|
public function test_removing_avatar_removes_file()
|
|
{
|
|
$this->filesystem->shouldReceive('has')->with('ABCDEFGHabcdefgh.png')->andReturn(true);
|
|
$this->filesystem->shouldReceive('delete')->with('ABCDEFGHabcdefgh.png')->once();
|
|
|
|
$user = new User();
|
|
$user->changeAvatarPath('ABCDEFGHabcdefgh.png');
|
|
// Necessary because AvatarUpload looks into the original attributes for the raw value,
|
|
// which isn't usually automatically updated without saving to the database
|
|
$user->syncOriginal();
|
|
|
|
$this->uploader->remove($user);
|
|
|
|
// Simulate saving
|
|
foreach ($user->releaseAfterSaveCallbacks() as $callback) {
|
|
$callback($user);
|
|
}
|
|
$user->syncOriginal();
|
|
|
|
$this->assertEquals(null, $user->getRawOriginal('avatar_url'));
|
|
}
|
|
|
|
public function test_removing_url_avatar_removes_no_file()
|
|
{
|
|
$this->filesystem->shouldReceive('has')->with('https://example.com/avatar.png')->andReturn(false)->once();
|
|
$this->filesystem->shouldNotReceive('delete');
|
|
|
|
$user = new User();
|
|
$user->changeAvatarPath('https://example.com/avatar.png');
|
|
$user->syncOriginal();
|
|
|
|
$this->uploader->remove($user);
|
|
|
|
// Simulate saving
|
|
foreach ($user->releaseAfterSaveCallbacks() as $callback) {
|
|
$callback($user);
|
|
}
|
|
$user->syncOriginal();
|
|
|
|
$this->assertEquals(null, $user->getRawOriginal('avatar_url'));
|
|
}
|
|
|
|
public function test_changing_avatar_removes_file()
|
|
{
|
|
$this->filesystem->shouldReceive('put')->once();
|
|
$this->filesystem->shouldReceive('has')->with('ABCDEFGHabcdefgh.png')->andReturn(true);
|
|
$this->filesystem->shouldReceive('delete')->with('ABCDEFGHabcdefgh.png')->once();
|
|
|
|
$user = new User();
|
|
$user->changeAvatarPath('ABCDEFGHabcdefgh.png');
|
|
$user->syncOriginal();
|
|
|
|
$this->uploader->upload($user, ImageManagerStatic::canvas(50, 50));
|
|
|
|
// Simulate saving
|
|
foreach ($user->releaseAfterSaveCallbacks() as $callback) {
|
|
$callback($user);
|
|
}
|
|
$user->syncOriginal();
|
|
|
|
$this->assertNotEquals('ABCDEFGHabcdefgh.png', $user->getRawOriginal('avatar_url'));
|
|
}
|
|
}
|