use BookStack\Entities\Models\Entity;
use BookStack\Permissions\PermissionApplicator;
use BookStack\Users\Models\User;
+use Illuminate\Support\Facades\Log;
abstract class BaseNotificationHandler implements NotificationHandler
{
}
// Send the notification
- $user->notify(new $notification($detail, $initiator));
+ try {
+ $user->notify(new $notification($detail, $initiator));
+ } catch (\Exception $exception) {
+ Log::error("Failed to send email notification to user [id:{$user->id}] with error: {$exception->getMessage()}");
+ }
}
}
}
use BookStack\Activity\WatchLevels;
use BookStack\Entities\Models\Entity;
use BookStack\Settings\UserNotificationPreferences;
+use Illuminate\Contracts\Notifications\Dispatcher;
+use Illuminate\Support\Facades\Mail;
use Illuminate\Support\Facades\Notification;
use Tests\TestCase;
}
}
+ public function test_failed_notifications_dont_block_and_log_errors()
+ {
+ $logger = $this->withTestLogger();
+ $editor = $this->users->editor();
+ $admin = $this->users->admin();
+ $page = $this->entities->page();
+ $book = $page->book;
+ $activityLogger = app()->make(ActivityLogger::class);
+
+ $watches = new UserEntityWatchOptions($editor, $book);
+ $watches->updateLevelByValue(WatchLevels::UPDATES);
+
+ $mockDispatcher = $this->mock(Dispatcher::class);
+ $mockDispatcher->shouldReceive('send')->once()
+ ->andThrow(\Exception::class, 'Failed to connect to mail server');
+
+ $this->actingAs($admin);
+
+ $activityLogger->add(ActivityType::PAGE_UPDATE, $page);
+
+ $this->assertTrue($logger->hasErrorThatContains("Failed to send email notification to user [id:{$editor->id}] with error: Failed to connect to mail server"));
+ }
+
public function test_notifications_not_sent_if_lacking_view_permission_for_related_item()
{
$notifications = Notification::fake();