From 993b60781ac6d205efbc59c2581f834adb11595f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ole=20J=C3=B8rgen=20Skogstad?= Date: Sat, 7 Sep 2024 23:46:27 +0200 Subject: [PATCH 1/3] create test --- .../DialogGenerator.cs | 17 +++++ .../Dialogs/Commands/UpdateDialogTests.cs | 68 +++++++++++++++++++ 2 files changed, 85 insertions(+) diff --git a/src/Digdir.Tool.Dialogporten.GenerateFakeData/DialogGenerator.cs b/src/Digdir.Tool.Dialogporten.GenerateFakeData/DialogGenerator.cs index 68072281e..15ffde70e 100644 --- a/src/Digdir.Tool.Dialogporten.GenerateFakeData/DialogGenerator.cs +++ b/src/Digdir.Tool.Dialogporten.GenerateFakeData/DialogGenerator.cs @@ -7,6 +7,7 @@ using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities; using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Actions; using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Activities; +using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Transmissions; using Digdir.Domain.Dialogporten.Domain.Http; using Medo; @@ -227,6 +228,22 @@ private static int CalculateControlDigit(string input, int[] weights) public static CreateDialogDialogActivityDto GenerateFakeDialogActivity(DialogActivityType.Values? type = null) => GenerateFakeDialogActivities(1, type)[0]; + public static List GenerateFakeDialogTransmissions(int? count = null, + DialogTransmissionType.Values? type = null) + { + return new Faker() + .RuleFor(o => o.Id, _ => Uuid7.NewUuid7().ToGuid(true)) + .RuleFor(o => o.CreatedAt, f => f.Date.Past()) + .RuleFor(o => o.Type, f => type ?? f.PickRandom()) + .RuleFor(o => o.Sender, _ => new() { ActorType = ActorType.Values.ServiceOwner }) + .RuleFor(o => o.Content, _ => new() + { + Title = new() { Value = GenerateFakeLocalizations(1) }, + Summary = new() { Value = GenerateFakeLocalizations(3) } + }) + .Generate(count ?? new Randomizer().Number(1, 4)); + } + public static List GenerateFakeDialogActivities(int? count = null, DialogActivityType.Values? type = null) { return new Faker() diff --git a/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs b/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs index c1dafe4bd..e7eb62125 100644 --- a/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs +++ b/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs @@ -4,8 +4,10 @@ using Digdir.Domain.Dialogporten.Application.Integration.Tests.Common; using Digdir.Domain.Dialogporten.Domain.Actors; using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Activities; +using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Transmissions; using Digdir.Tool.Dialogporten.GenerateFakeData; using FluentAssertions; +using Microsoft.IdentityModel.Tokens; namespace Digdir.Domain.Dialogporten.Application.Integration.Tests.Features.V1.ServiceOwner.Dialogs.Commands; @@ -42,6 +44,72 @@ public async Task New_Activity_Should_Be_Able_To_Refer_To_Old_Activity() result.Should().NotBeNull(); } + [Fact] + public async Task Cannot_Include_Old_Activities_To_UpdateCommand() + { + // Arrange + var (_, createCommandResponse) = await GenerateDialogWithActivity(); + var getDialogQuery = new GetDialogQuery { DialogId = createCommandResponse.AsT0.Value }; + var getDialogDto = await Application.Send(getDialogQuery); + + var mapper = Application.GetMapper(); + var updateDialogDto = mapper.Map(getDialogDto.AsT0); + + // Ref. old activity + updateDialogDto.Activities.Add(new UpdateDialogDialogActivityDto + { + Id = getDialogDto.AsT0.Activities.First().Id, + Type = DialogActivityType.Values.DialogCreated, + PerformedBy = new UpdateDialogDialogActivityPerformedByActorDto + { + ActorType = ActorType.Values.ServiceOwner + } + }); + + // Act + var updateResponse = await Application.Send(new UpdateDialogCommand { Id = createCommandResponse.AsT0.Value, Dto = updateDialogDto }); + + // Assert + updateResponse.TryPickT5(out var domainError, out _).Should().BeTrue(); + domainError.Should().NotBeNull(); + } + + [Fact] + public async Task Cannot_Include_Old_Transmissions_In_UpdateCommand() + { + // Arrange + var createDialogCommand = DialogGenerator.GenerateSimpleFakeDialog(); + var existingTransmission = DialogGenerator.GenerateFakeDialogTransmissions(count: 1).First(); + createDialogCommand.Transmissions.Add(existingTransmission); + var createCommandResponse = await Application.Send(createDialogCommand); + + var getDialogQuery = new GetDialogQuery { DialogId = createCommandResponse.AsT0.Value }; + var getDialogDto = await Application.Send(getDialogQuery); + + var mapper = Application.GetMapper(); + var updateDialogDto = mapper.Map(getDialogDto.AsT0); + + // Ref. old transmission + updateDialogDto.Transmissions.Add(new UpdateDialogDialogTransmissionDto + { + Id = existingTransmission.Id, + Type = DialogTransmissionType.Values.Information, + Sender = new() { ActorType = ActorType.Values.ServiceOwner }, + Content = new() + { + Title = new() { Value = DialogGenerator.GenerateFakeLocalizations(3) }, + Summary = new() { Value = DialogGenerator.GenerateFakeLocalizations(3) } + } + }); + + // Act + var updateResponse = await Application.Send(new UpdateDialogCommand { Id = createCommandResponse.AsT0.Value, Dto = updateDialogDto }); + + // Assert + updateResponse.TryPickT5(out var domainError, out _).Should().BeTrue(); + domainError.Should().NotBeNull(); + } + private async Task<(CreateDialogCommand, CreateDialogResult)> GenerateDialogWithActivity() { var createDialogCommand = DialogGenerator.GenerateSimpleFakeDialog(); From 5ab282528583753e9f20379469ec21d37a302999 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ole=20J=C3=B8rgen=20Skogstad?= Date: Sat, 7 Sep 2024 23:47:55 +0200 Subject: [PATCH 2/3] return early on domain error --- .../Dialogs/Commands/Update/UpdateDialogCommand.cs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/Digdir.Domain.Dialogporten.Application/Features/V1/ServiceOwner/Dialogs/Commands/Update/UpdateDialogCommand.cs b/src/Digdir.Domain.Dialogporten.Application/Features/V1/ServiceOwner/Dialogs/Commands/Update/UpdateDialogCommand.cs index 7ac9ca025..5d7430510 100644 --- a/src/Digdir.Domain.Dialogporten.Application/Features/V1/ServiceOwner/Dialogs/Commands/Update/UpdateDialogCommand.cs +++ b/src/Digdir.Domain.Dialogporten.Application/Features/V1/ServiceOwner/Dialogs/Commands/Update/UpdateDialogCommand.cs @@ -183,9 +183,7 @@ private async Task AppendActivity(DialogEntity dialog, UpdateDialogDto dto, Canc var existingIds = await _db.GetExistingIds(newDialogActivities, cancellationToken); if (existingIds.Count != 0) { - _domainContext.AddError( - nameof(UpdateDialogDto.Activities), - $"Entity '{nameof(DialogActivity)}' with the following key(s) already exists: ({string.Join(", ", existingIds)})."); + _domainContext.AddError(DomainFailure.EntityExists(existingIds)); return; } @@ -257,6 +255,7 @@ private async Task AppendTransmission(DialogEntity dialog, UpdateDialogDto dto, if (existingIds.Count != 0) { _domainContext.AddError(DomainFailure.EntityExists(existingIds)); + return; } dialog.Transmissions.AddRange(newDialogTransmissions); From 46ea3959f6b589da4075016f3cac0aa84eeb9c39 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ole=20J=C3=B8rgen=20Skogstad?= Date: Sun, 8 Sep 2024 15:55:47 +0200 Subject: [PATCH 3/3] cl --- .../V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs b/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs index e7eb62125..167555250 100644 --- a/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs +++ b/tests/Digdir.Domain.Dialogporten.Application.Integration.Tests/Features/V1/ServiceOwner/Dialogs/Commands/UpdateDialogTests.cs @@ -7,7 +7,6 @@ using Digdir.Domain.Dialogporten.Domain.Dialogs.Entities.Transmissions; using Digdir.Tool.Dialogporten.GenerateFakeData; using FluentAssertions; -using Microsoft.IdentityModel.Tokens; namespace Digdir.Domain.Dialogporten.Application.Integration.Tests.Features.V1.ServiceOwner.Dialogs.Commands; @@ -72,6 +71,7 @@ public async Task Cannot_Include_Old_Activities_To_UpdateCommand() // Assert updateResponse.TryPickT5(out var domainError, out _).Should().BeTrue(); domainError.Should().NotBeNull(); + domainError.Errors.Should().Contain(e => e.ErrorMessage.Contains("already exists")); } [Fact] @@ -108,6 +108,7 @@ public async Task Cannot_Include_Old_Transmissions_In_UpdateCommand() // Assert updateResponse.TryPickT5(out var domainError, out _).Should().BeTrue(); domainError.Should().NotBeNull(); + domainError.Errors.Should().Contain(e => e.ErrorMessage.Contains("already exists")); } private async Task<(CreateDialogCommand, CreateDialogResult)> GenerateDialogWithActivity()