mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
6.1 KiB
191 lines
6.1 KiB
// ==========================================================================
|
|
// Squidex Headless CMS
|
|
// ==========================================================================
|
|
// Copyright (c) Squidex UG (haftungsbeschraenkt)
|
|
// All rights reserved. Licensed under the MIT license.
|
|
// ==========================================================================
|
|
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using FakeItEasy;
|
|
using NodaTime;
|
|
using Squidex.Domain.Apps.Events.Apps;
|
|
using Squidex.Infrastructure;
|
|
using Squidex.Infrastructure.EventSourcing;
|
|
using Squidex.Infrastructure.Log;
|
|
using Squidex.Shared.Users;
|
|
using Xunit;
|
|
|
|
namespace Squidex.Domain.Apps.Entities.History.Notifications
|
|
{
|
|
public class NotificationEmailEventConsumerTests
|
|
{
|
|
private readonly INotificationEmailSender emailSender = A.Fake<INotificationEmailSender>();
|
|
private readonly IUserResolver userResolver = A.Fake<IUserResolver>();
|
|
private readonly IUser assigner = A.Fake<IUser>();
|
|
private readonly IUser assignee = A.Fake<IUser>();
|
|
private readonly ISemanticLog log = A.Fake<ISemanticLog>();
|
|
private readonly string assignerId = Guid.NewGuid().ToString();
|
|
private readonly string assigneeId = Guid.NewGuid().ToString();
|
|
private readonly string appName = "my-app";
|
|
private readonly NotificationEmailEventConsumer sut;
|
|
|
|
public NotificationEmailEventConsumerTests()
|
|
{
|
|
A.CallTo(() => emailSender.IsActive)
|
|
.Returns(true);
|
|
|
|
A.CallTo(() => userResolver.FindByIdOrEmailAsync(assignerId))
|
|
.Returns(assigner);
|
|
|
|
A.CallTo(() => userResolver.FindByIdOrEmailAsync(assigneeId))
|
|
.Returns(assignee);
|
|
|
|
sut = new NotificationEmailEventConsumer(emailSender, userResolver, log);
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_if_contributors_assigned_by_clients()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Client, true);
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotResolveUser();
|
|
MustNotSendEmail();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_for_initial_owner()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, false, streamNumber: 1);
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotSendEmail();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_for_old_events()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true, instant: SystemClock.Instance.GetCurrentInstant().Minus(Duration.FromHours(50)));
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotResolveUser();
|
|
MustNotSendEmail();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_for_old_contributor()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true, isNewContributor: false);
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotResolveUser();
|
|
MustNotSendEmail();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_if_sender_not_active()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true);
|
|
|
|
A.CallTo(() => emailSender.IsActive)
|
|
.Returns(false);
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotResolveUser();
|
|
MustNotSendEmail();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_if_assigner_not_found()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true);
|
|
|
|
A.CallTo(() => userResolver.FindByIdOrEmailAsync(assignerId))
|
|
.Returns(Task.FromResult<IUser>(null));
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotSendEmail();
|
|
MustLogWarning();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_not_send_email_if_assignee_not_found()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true);
|
|
|
|
A.CallTo(() => userResolver.FindByIdOrEmailAsync(assigneeId))
|
|
.Returns(Task.FromResult<IUser>(null));
|
|
|
|
await sut.On(@event);
|
|
|
|
MustNotSendEmail();
|
|
MustLogWarning();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_send_email_for_new_user()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, true);
|
|
|
|
await sut.On(@event);
|
|
|
|
A.CallTo(() => emailSender.SendContributorEmailAsync(assigner, assignee, appName, true))
|
|
.MustHaveHappened();
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Should_send_email_for_existing_user()
|
|
{
|
|
var @event = CreateEvent(RefTokenType.Subject, false);
|
|
|
|
await sut.On(@event);
|
|
|
|
A.CallTo(() => emailSender.SendContributorEmailAsync(assigner, assignee, appName, false))
|
|
.MustHaveHappened();
|
|
}
|
|
|
|
private void MustLogWarning()
|
|
{
|
|
A.CallTo(() => log.Log(SemanticLogLevel.Warning, A<None>.Ignored, A<Action<None, IObjectWriter>>.Ignored))
|
|
.MustHaveHappened();
|
|
}
|
|
|
|
private void MustNotResolveUser()
|
|
{
|
|
A.CallTo(() => userResolver.FindByIdOrEmailAsync(A<string>.Ignored))
|
|
.MustNotHaveHappened();
|
|
}
|
|
|
|
private void MustNotSendEmail()
|
|
{
|
|
A.CallTo(() => emailSender.SendContributorEmailAsync(A<IUser>.Ignored, A<IUser>.Ignored, A<string>.Ignored, A<bool>.Ignored))
|
|
.MustNotHaveHappened();
|
|
}
|
|
|
|
private Envelope<IEvent> CreateEvent(string assignerType, bool isNewUser, bool isNewContributor = true, Instant? instant = null, int streamNumber = 2)
|
|
{
|
|
var @event = new AppContributorAssigned
|
|
{
|
|
Actor = new RefToken(assignerType, assignerId),
|
|
AppId = NamedId.Of(Guid.NewGuid(), appName),
|
|
ContributorId = assigneeId,
|
|
IsCreated = isNewUser,
|
|
IsAdded = isNewContributor,
|
|
};
|
|
|
|
var envelope = Envelope.Create(@event);
|
|
|
|
envelope.SetTimestamp(instant ?? SystemClock.Instance.GetCurrentInstant());
|
|
envelope.SetEventStreamNumber(streamNumber);
|
|
|
|
return envelope;
|
|
}
|
|
}
|
|
}
|
|
|