-<?php namespace Tests\Uploads;
+<?php
+
+namespace Tests\Uploads;
-use BookStack\Auth\User;
use BookStack\Exceptions\HttpFetchException;
use BookStack\Uploads\HttpFetcher;
-use Illuminate\Support\Facades\Log;
+use BookStack\Uploads\UserAvatars;
+use BookStack\Users\Models\User;
use Tests\TestCase;
class AvatarTest extends TestCase
{
- use UsesImages;
-
-
- protected function createUserRequest($user)
+ protected function createUserRequest($user): User
{
$this->asAdmin()->post('/settings/users/create', [
- 'name' => $user->name,
- 'email' => $user->email,
- 'password' => 'testing',
- 'password-confirm' => 'testing',
+ 'name' => $user->name,
+ 'email' => $user->email,
+ 'password' => 'testing101',
+ 'password-confirm' => 'testing101',
]);
- return User::where('email', '=', $user->email)->first();
+
+ return User::query()->where('email', '=', $user->email)->first();
}
protected function assertImageFetchFrom(string $url)
$http->shouldReceive('fetch')
->once()->with($url)
- ->andReturn($this->getTestImageContent());
+ ->andReturn($this->files->pngImageData());
}
protected function deleteUserImage(User $user)
{
- $this->deleteImage($user->avatar->path);
+ $this->files->deleteAtRelativePath($user->avatar->path);
}
public function test_gravatar_fetched_on_user_create()
config()->set([
'services.disable_services' => false,
]);
- $user = factory(User::class)->make();
- $this->assertImageFetchFrom('https://www.gravatar.com/avatar/'.md5(strtolower($user->email)).'?s=500&d=identicon');
+ $user = User::factory()->make();
+ $this->assertImageFetchFrom('https://www.gravatar.com/avatar/' . md5(strtolower($user->email)) . '?s=500&d=identicon');
$user = $this->createUserRequest($user);
$this->assertDatabaseHas('images', [
- 'type' => 'user',
- 'created_by' => $user->id
+ 'type' => 'user',
+ 'created_by' => $user->id,
]);
$this->deleteUserImage($user);
}
-
public function test_custom_url_used_if_set()
{
config()->set([
'services.disable_services' => false,
- 'services.avatar_url' => 'https://example.com/${email}/${hash}/${size}',
+ 'services.avatar_url' => 'https://example.com/${email}/${hash}/${size}',
]);
- $user = factory(User::class)->make();
- $url = 'https://example.com/'. urlencode(strtolower($user->email)) .'/'. md5(strtolower($user->email)).'/500';
+ $user = User::factory()->make();
+ $url = 'https://example.com/' . urlencode(strtolower($user->email)) . '/' . md5(strtolower($user->email)) . '/500';
$this->assertImageFetchFrom($url);
$user = $this->createUserRequest($user);
'services.disable_services' => true,
]);
- $user = factory(User::class)->make();
+ $user = User::factory()->make();
+
+ $http = $this->mock(HttpFetcher::class);
+ $http->shouldNotReceive('fetch');
+
+ $this->createUserRequest($user);
+ }
+
+ public function test_avatar_not_fetched_if_avatar_url_option_set_to_false()
+ {
+ config()->set([
+ 'services.disable_services' => false,
+ 'services.avatar_url' => false,
+ ]);
+
+ $user = User::factory()->make();
$http = $this->mock(HttpFetcher::class);
$http->shouldNotReceive('fetch');
$logger = $this->withTestLogger();
- $user = factory(User::class)->make();
+ $user = User::factory()->make();
$this->createUserRequest($user);
$this->assertTrue($logger->hasError('Failed to save user avatar image'));
}
+ public function test_exception_message_on_failed_fetch()
+ {
+ // set wrong url
+ config()->set([
+ 'services.disable_services' => false,
+ 'services.avatar_url' => 'http_malformed_url/${email}/${hash}/${size}',
+ ]);
+
+ $user = User::factory()->make();
+ $avatar = app()->make(UserAvatars::class);
+ $url = 'http_malformed_url/' . urlencode(strtolower($user->email)) . '/' . md5(strtolower($user->email)) . '/500';
+ $logger = $this->withTestLogger();
+
+ $avatar->fetchAndAssignToUser($user);
+
+ $this->assertTrue($logger->hasError('Failed to save user avatar image'));
+ $exception = $logger->getRecords()[0]['context']['exception'];
+ $this->assertEquals(new HttpFetchException(
+ 'Cannot get image from ' . $url,
+ 6,
+ (new HttpFetchException('Could not resolve host: http_malformed_url', 6))
+ ), $exception);
+ }
}