* Introduce new AuditEntryService - Moved logic related to the IAuditEntryRepository from the AuditService to the new service - Introduced new Async methods - Using ids (for easier transition from the previous Write method) - Using keys - Moved and updated integration tests related to the audit entries to a new test class `AuditEntryServiceTests` - Added unit tests class `AuditEntryServiceTests` and added a few unit tests - Added migration to add columns for `performingUserKey` and `affectedUserKey` and convert existing user ids - Adjusted usages of the old AuditService.Write method to use the new one (mostly notification handlers) * Audit service rework - Added new async and paged methods - Marked (now) redundant methods as obsolete - Updated all of the usages to use the non-obsolete methods - Added unit tests class `AuditServiceTests` and some unit tests - Updated existing integration test * Apply suggestions from code review * Small improvement * Update src/Umbraco.Core/Services/AuditService.cs * Some minor adjustments following the merge * Delete unnecessary file * Small cleanup on the tests
50 lines
1.6 KiB
C#
50 lines
1.6 KiB
C#
// Copyright (c) Umbraco.
|
|
// See LICENSE for more details.
|
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using NUnit.Framework;
|
|
using Umbraco.Cms.Core;
|
|
using Umbraco.Cms.Core.Models;
|
|
using Umbraco.Cms.Core.Services;
|
|
using Umbraco.Cms.Core.Services.Implement;
|
|
using Umbraco.Cms.Tests.Common.Testing;
|
|
using Umbraco.Cms.Tests.Integration.Testing;
|
|
|
|
namespace Umbraco.Cms.Tests.Integration.Umbraco.Infrastructure.Services;
|
|
|
|
[TestFixture]
|
|
[UmbracoTest(Database = UmbracoTestOptions.Database.NewSchemaPerTest)]
|
|
internal sealed class AuditServiceTests : UmbracoIntegrationTest
|
|
{
|
|
[Test]
|
|
public async Task GetUserLogs()
|
|
{
|
|
var sut = (AuditService)Services.GetRequiredService<IAuditService>();
|
|
|
|
var eventDateUtc = DateTime.UtcNow.AddDays(-1);
|
|
|
|
const int numberOfEntries = 10;
|
|
for (var i = 0; i < numberOfEntries; i++)
|
|
{
|
|
eventDateUtc = eventDateUtc.AddMinutes(1);
|
|
await sut.AddAsync(AuditType.Unpublish, Constants.Security.SuperUserKey, 33, string.Empty, "blah");
|
|
}
|
|
|
|
await sut.AddAsync(AuditType.Publish, Constants.Security.SuperUserKey, 33, string.Empty, "blah");
|
|
|
|
var logs = (await sut.GetPagedItemsByUserAsync(
|
|
Constants.Security.SuperUserKey,
|
|
0,
|
|
int.MaxValue,
|
|
auditTypeFilter: [AuditType.Unpublish])).Items.ToArray();
|
|
|
|
Assert.Multiple(() =>
|
|
{
|
|
Assert.IsNotNull(logs);
|
|
CollectionAssert.AllItemsAreNotNull(logs);
|
|
Assert.AreEqual(numberOfEntries, logs.Length);
|
|
Assert.AreEqual(numberOfEntries, logs.Count(x => x.AuditType == AuditType.Unpublish));
|
|
});
|
|
}
|
|
}
|