mirror of
https://github.com/bitwarden/server.git
synced 2024-12-01 13:43:23 +01:00
f44a59f7a9
* Allow for binning of comb IDs by date and value
* Introduce notification hub pool
* Replace device type sharding with comb + range sharding
* Fix proxy interface
* Use enumerable services for multiServiceNotificationHub
* Fix push interface usage
* Fix push notification service dependencies
* Fix push notification keys
* Fixup documentation
* Remove deprecated settings
* Fix tests
* PascalCase method names
* Remove unused request model properties
* Remove unused setting
* Improve DateFromComb precision
* Prefer readonly service enumerable
* Pascal case template holes
* Name TryParse methods TryParse
* Apply suggestions from code review
Co-authored-by: Justin Baur <19896123+justindbaur@users.noreply.github.com>
* AllClients is a set of clients and must be deduplicated
* Fix registration start time
* Add logging to initialization of a notification hub
* more logging
* Add lower level logging for hub settings
* Log when connection is resolved
* Improve log message
* Log pushes to notification hub
* temporarily elevate log messages for visibility
* Log in multi-service when relaying to another push service
* Revert to more reasonable logging free of user information
* Fixup merge
Deleting user was extracted to a command in #4803, this updates that work to use just the device ids as I did elsewhere in abd67e8ec
* Do not use bouncy castle exception types
* Add required services for logging
---------
Co-authored-by: Justin Baur <19896123+justindbaur@users.noreply.github.com>
Co-authored-by: bnagawiecki <107435978+bnagawiecki@users.noreply.github.com>
43 lines
1.4 KiB
C#
43 lines
1.4 KiB
C#
using Bit.Core.NotificationHub;
|
|
using Bit.Core.Repositories;
|
|
using Bit.Core.Services;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.Extensions.Logging;
|
|
using NSubstitute;
|
|
using Xunit;
|
|
|
|
namespace Bit.Core.Test.NotificationHub;
|
|
|
|
public class NotificationHubPushNotificationServiceTests
|
|
{
|
|
private readonly NotificationHubPushNotificationService _sut;
|
|
|
|
private readonly IInstallationDeviceRepository _installationDeviceRepository;
|
|
private readonly INotificationHubPool _notificationHubPool;
|
|
private readonly IHttpContextAccessor _httpContextAccessor;
|
|
private readonly ILogger<NotificationsApiPushNotificationService> _logger;
|
|
|
|
public NotificationHubPushNotificationServiceTests()
|
|
{
|
|
_installationDeviceRepository = Substitute.For<IInstallationDeviceRepository>();
|
|
_httpContextAccessor = Substitute.For<IHttpContextAccessor>();
|
|
_notificationHubPool = Substitute.For<INotificationHubPool>();
|
|
_logger = Substitute.For<ILogger<NotificationsApiPushNotificationService>>();
|
|
|
|
_sut = new NotificationHubPushNotificationService(
|
|
_installationDeviceRepository,
|
|
_notificationHubPool,
|
|
_httpContextAccessor,
|
|
_logger
|
|
);
|
|
}
|
|
|
|
// Remove this test when we add actual tests. It only proves that
|
|
// we've properly constructed the system under test.
|
|
[Fact(Skip = "Needs additional work")]
|
|
public void ServiceExists()
|
|
{
|
|
Assert.NotNull(_sut);
|
|
}
|
|
}
|