From f09c22609984e2c2d371f6cc3256609fd3b614ad Mon Sep 17 00:00:00 2001 From: Andrew Horth Date: Tue, 17 Dec 2024 18:09:06 +0000 Subject: [PATCH] Added logging to sync helper to highlight when we're getting CRM rate limiting --- TeachingRecordSystem/Dockerfile | 10 ++ .../Jobs/SyncAllInductionsFromCrmJob.cs | 7 +- .../Services/TrsDataSync/TrsDataSyncHelper.cs | 96 ++++++++++++++----- .../CrmClientFixture.cs | 7 +- .../ApiSchema/EventMapperTestBase.cs | 7 +- .../Jobs/SyncAllInductionsFromCrmJobTests.cs | 3 +- .../Jobs/SyncFromCrmJobFixture.cs | 13 ++- .../Jobs/SyncFromCrmJobTestBase.cs | 3 + .../DqtOutbox/OutboxMessageHandlerTests.cs | 7 +- .../Gias/EstablishmentRefresherTests.cs | 7 +- .../Tps/TpsEstablishmentRefresherTests.cs | 7 +- .../PersonMatchingServiceTests.cs | 7 +- .../TrsDataSyncHelperTests.Induction.cs | 2 +- .../TrsDataSync/TrsDataSyncHelperTests.cs | 7 +- .../TrsDataSync/TrsDataSyncServiceFixture.cs | 7 +- .../TpsCsvExtractProcessorTests.cs | 7 +- .../WorkforceDataExporterTests.cs | 7 +- 17 files changed, 153 insertions(+), 51 deletions(-) diff --git a/TeachingRecordSystem/Dockerfile b/TeachingRecordSystem/Dockerfile index 198bf0c36..34849082f 100644 --- a/TeachingRecordSystem/Dockerfile +++ b/TeachingRecordSystem/Dockerfile @@ -34,4 +34,14 @@ RUN apk --no-cache add msttcorefonts-installer fontconfig && \ update-ms-fonts && \ fc-cache -f +# Install SQL Server tools needed to be able to query the reporting DB to help debugging +RUN apk add curl + +RUN curl -O https://download.microsoft.com/download/b/9/f/b9f3cce4-3925-46d4-9f46-da08869c6486/msodbcsql18_18.0.1.1-1_amd64.apk && \ + curl -O https://download.microsoft.com/download/b/9/f/b9f3cce4-3925-46d4-9f46-da08869c6486/mssql-tools18_18.0.1.1-1_amd64.apk + +RUN apk add --allow-untrusted msodbcsql18_18.0.1.1-1_amd64.apk && \ + apk add --allow-untrusted mssql-tools18_18.0.1.1-1_amd64.apk && \ + rm -f msodbcsql18_18.0.1.1-1_amd64.apk mssql-tools18_18.0.1.1-1_amd64.apk + ENV PATH="${PATH}:/Apps/TrsCli" diff --git a/TeachingRecordSystem/src/TeachingRecordSystem.Core/Jobs/SyncAllInductionsFromCrmJob.cs b/TeachingRecordSystem/src/TeachingRecordSystem.Core/Jobs/SyncAllInductionsFromCrmJob.cs index 47edfbcde..f322802b9 100644 --- a/TeachingRecordSystem/src/TeachingRecordSystem.Core/Jobs/SyncAllInductionsFromCrmJob.cs +++ b/TeachingRecordSystem/src/TeachingRecordSystem.Core/Jobs/SyncAllInductionsFromCrmJob.cs @@ -1,5 +1,6 @@ using System.ServiceModel; using Hangfire; +using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Microsoft.Xrm.Sdk; using Microsoft.Xrm.Sdk.Query; @@ -14,15 +15,18 @@ public class SyncAllInductionsFromCrmJob private readonly ICrmServiceClientProvider _crmServiceClientProvider; private readonly TrsDataSyncHelper _trsDataSyncHelper; private readonly IOptions _syncOptionsAccessor; + private readonly ILogger _logger; public SyncAllInductionsFromCrmJob( ICrmServiceClientProvider crmServiceClientProvider, TrsDataSyncHelper trsDataSyncHelper, - IOptions syncOptionsAccessor) + IOptions syncOptionsAccessor, + ILoggerFactory loggerFactory) { _crmServiceClientProvider = crmServiceClientProvider; _trsDataSyncHelper = trsDataSyncHelper; _syncOptionsAccessor = syncOptionsAccessor; + _logger = loggerFactory.CreateLogger(); } public async Task ExecuteAsync(bool createMigratedEvent, bool dryRun, CancellationToken cancellationToken) @@ -57,6 +61,7 @@ public async Task ExecuteAsync(bool createMigratedEvent, bool dryRun, Cancellati } catch (FaultException fex) when (fex.IsCrmRateLimitException(out var retryAfter)) { + _logger.LogWarning("Hit CRM service limits; error code: {ErrorCode}", fex.Detail.ErrorCode); await Task.Delay(retryAfter, cancellationToken); continue; } diff --git a/TeachingRecordSystem/src/TeachingRecordSystem.Core/Services/TrsDataSync/TrsDataSyncHelper.cs b/TeachingRecordSystem/src/TeachingRecordSystem.Core/Services/TrsDataSync/TrsDataSyncHelper.cs index e0a81682a..a2b13a963 100644 --- a/TeachingRecordSystem/src/TeachingRecordSystem.Core/Services/TrsDataSync/TrsDataSyncHelper.cs +++ b/TeachingRecordSystem/src/TeachingRecordSystem.Core/Services/TrsDataSync/TrsDataSyncHelper.cs @@ -4,6 +4,7 @@ using System.ServiceModel; using Microsoft.Crm.Sdk.Messages; using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using Microsoft.Xrm.Sdk; using Microsoft.Xrm.Sdk.Messages; @@ -16,11 +17,7 @@ namespace TeachingRecordSystem.Core.Services.TrsDataSync; -public class TrsDataSyncHelper( - NpgsqlDataSource trsDbDataSource, - [FromKeyedServices(TrsDataSyncService.CrmClientName)] IOrganizationServiceAsync2 organizationService, - ReferenceDataCache referenceDataCache, - IClock clock) +public class TrsDataSyncHelper { private delegate Task SyncEntitiesHandler(IReadOnlyCollection entities, bool ignoreInvalid, bool dryRun, CancellationToken cancellationToken); @@ -37,10 +34,41 @@ public class TrsDataSyncHelper( }; private readonly ISubject _syncedEntitiesSubject = new Subject(); + private readonly NpgsqlDataSource _trsDbDataSource; + private readonly IOrganizationServiceAsync2 _organizationService; + private readonly ReferenceDataCache _referenceDataCache; + private readonly IClock _clock; + private readonly ILogger _logger; + private bool? isFakeXrm; + + public TrsDataSyncHelper( + NpgsqlDataSource trsDbDataSource, + [FromKeyedServices(TrsDataSyncService.CrmClientName)] IOrganizationServiceAsync2 organizationService, + ReferenceDataCache referenceDataCache, + IClock clock, + ILoggerFactory loggerFactory) + { + _trsDbDataSource = trsDbDataSource; + _organizationService = organizationService; + _referenceDataCache = referenceDataCache; + _clock = clock; + _logger = loggerFactory.CreateLogger(); + } public IObservable GetSyncedEntitiesObservable() => _syncedEntitiesSubject; - private bool IsFakeXrm { get; } = organizationService.GetType().FullName == "Castle.Proxies.ObjectProxy_2"; + private bool IsFakeXrm + { + get + { + if (isFakeXrm is null) + { + isFakeXrm = _organizationService.GetType().FullName == "Castle.Proxies.ObjectProxy_2"; + } + + return isFakeXrm!.Value; + } + } public static (string EntityLogicalName, string[] AttributeNames) GetEntityInfoForModelType(string modelType) { @@ -142,7 +170,7 @@ public async Task DeleteRecordsAsync(string modelType, IReadOnlyCollection throw new NotSupportedException($"Cannot delete a {modelType}."); } - await using var connection = await trsDbDataSource.OpenConnectionAsync(cancellationToken); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(cancellationToken); using (var cmd = connection.CreateCommand()) { @@ -161,7 +189,7 @@ public async Task DeleteRecordsAsync(string modelType, IReadOnlyCollection return null; } - await using var connection = await trsDbDataSource.OpenConnectionAsync(); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(); using (var cmd = connection.CreateCommand()) { @@ -221,7 +249,7 @@ public async Task> SyncPersonsAsync(IReadOnlyCollectio var modelTypeSyncInfo = GetModelTypeSyncInfo(ModelTypes.Person); - await using var connection = await trsDbDataSource.OpenConnectionAsync(cancellationToken); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(cancellationToken); using var txn = await connection.BeginTransactionAsync(cancellationToken); using (var createTempTableCommand = connection.CreateCommand()) @@ -247,7 +275,7 @@ public async Task> SyncPersonsAsync(IReadOnlyCollectio using (var mergeCommand = connection.CreateCommand()) { mergeCommand.CommandText = modelTypeSyncInfo.UpsertStatement; - mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, clock.UtcNow)); + mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, _clock.UtcNow)); mergeCommand.Transaction = txn; await mergeCommand.ExecuteNonQueryAsync(); } @@ -385,7 +413,7 @@ private async Task SyncInductionsAsync( { var modelTypeSyncInfo = GetModelTypeSyncInfo(ModelTypes.Induction); - await using var connection = await trsDbDataSource.OpenConnectionAsync(cancellationToken); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(cancellationToken); var toSync = inductions.ToList(); @@ -416,7 +444,7 @@ private async Task SyncInductionsAsync( using (var mergeCommand = connection.CreateCommand()) { mergeCommand.CommandText = modelTypeSyncInfo.UpsertStatement; - mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, clock.UtcNow)); + mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, _clock.UtcNow)); mergeCommand.Transaction = txn; using var reader = await mergeCommand.ExecuteReaderAsync(); while (await reader.ReadAsync(cancellationToken)) @@ -458,7 +486,7 @@ private async Task SyncInductionsAsync( .Where(e => e is IEventWithPersonId && !unsyncedContactIds.Any(c => c == ((IEventWithPersonId)e).PersonId)) .ToArray(); - await txn.SaveEventsAsync(eventsForSyncedContacts, "events_import", clock, cancellationToken); + await txn.SaveEventsAsync(eventsForSyncedContacts, "events_import", _clock, cancellationToken); if (!dryRun) { @@ -529,7 +557,7 @@ private async Task SyncAlertsAsync( var modelTypeSyncInfo = GetModelTypeSyncInfo(ModelTypes.Alert); - await using var connection = await trsDbDataSource.OpenConnectionAsync(cancellationToken); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(cancellationToken); var toSync = alerts.ToList(); @@ -560,12 +588,12 @@ private async Task SyncAlertsAsync( using (var mergeCommand = connection.CreateCommand()) { mergeCommand.CommandText = modelTypeSyncInfo.UpsertStatement; - mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, clock.UtcNow)); + mergeCommand.Parameters.Add(new NpgsqlParameter(NowParameterName, _clock.UtcNow)); mergeCommand.Transaction = txn; await mergeCommand.ExecuteNonQueryAsync(); } - await txn.SaveEventsAsync(events, "events_import", clock, cancellationToken); + await txn.SaveEventsAsync(events, "events_import", _clock, cancellationToken); if (!dryRun) { @@ -621,10 +649,10 @@ public async Task SyncEventsAsync(IReadOnlyCollection event var mapped = events.Select(e => EventInfo.Deserialize(e.dfeta_Payload).Event).ToArray(); - await using var connection = await trsDbDataSource.OpenConnectionAsync(cancellationToken); + await using var connection = await _trsDbDataSource.OpenConnectionAsync(cancellationToken); using var txn = await connection.BeginTransactionAsync(cancellationToken); - await txn.SaveEventsAsync(mapped, tempTableSuffix: "events_import", clock, cancellationToken); + await txn.SaveEventsAsync(mapped, tempTableSuffix: "events_import", _clock, cancellationToken); if (!dryRun) { @@ -800,7 +828,7 @@ private async Task> GetAuditRec { try { - response = (ExecuteMultipleResponse)await organizationService.ExecuteAsync(request, cancellationToken); + response = (ExecuteMultipleResponse)await _organizationService.ExecuteAsync(request, cancellationToken); } catch (FaultException fex) when (fex.IsCrmRateLimitException(out var retryAfter)) { @@ -854,7 +882,25 @@ private async Task GetEntitiesAsync( query.Criteria.AddCondition("statecode", ConditionOperator.Equal, 0); } - var response = await organizationService.RetrieveMultipleAsync(query, cancellationToken); + EntityCollection response; + while (true) + { + cancellationToken.ThrowIfCancellationRequested(); + + try + { + response = await _organizationService.RetrieveMultipleAsync(query, cancellationToken); + } + catch (FaultException fex) when (fex.IsCrmRateLimitException(out var retryAfter)) + { + _logger.LogWarning("Hit CRM service limits; error code: {ErrorCode}", fex.Detail.ErrorCode); + await Task.Delay(retryAfter, cancellationToken); + continue; + } + + break; + } + return response.Entities.Select(e => e.ToEntity()).ToArray(); } @@ -1421,7 +1467,7 @@ EventBase MapMigratedEvent(EntityVersionInfo snapshot, Inductio { EventId = Guid.NewGuid(), Key = $"{snapshot.Entity.Id}-Migrated", - CreatedUtc = clock.UtcNow, + CreatedUtc = _clock.UtcNow, RaisedBy = EventModels.RaisedByUserInfo.FromUserId(Core.DataStore.Postgres.Models.SystemUser.SystemUserId), PersonId = snapshot.Entity.dfeta_PersonId.Id, InductionStartDate = mappedInduction.InductionStartDate, @@ -1451,8 +1497,8 @@ EventModels.DqtInduction GetEventDqtInduction(dfeta_induction induction) bool ignoreInvalid, bool createMigratedEvent) { - var sanctionCodes = await referenceDataCache.GetSanctionCodesAsync(activeOnly: false); - var alertTypes = await referenceDataCache.GetAlertTypesAsync(); + var sanctionCodes = await _referenceDataCache.GetSanctionCodesAsync(activeOnly: false); + var alertTypes = await _referenceDataCache.GetAlertTypesAsync(); var alerts = new List(); var events = new List(); @@ -1486,7 +1532,7 @@ EventModels.DqtInduction GetEventDqtInduction(dfeta_induction induction) // If the record is deactivated then it's migrated as deleted if (s.StateCode == dfeta_sanctionState.Inactive) { - mapped.DeletedOn = clock.UtcNow; + mapped.DeletedOn = _clock.UtcNow; } else if (createMigratedEvent) { @@ -1603,7 +1649,7 @@ EventBase MapMigratedEvent(EntityVersionInfo snapshot) { EventId = Guid.NewGuid(), Key = $"{snapshot.Entity.Id}-Migrated", - CreatedUtc = clock.UtcNow, + CreatedUtc = _clock.UtcNow, RaisedBy = EventModels.RaisedByUserInfo.FromUserId(Core.DataStore.Postgres.Models.SystemUser.SystemUserId), PersonId = snapshot.Entity.dfeta_PersonId.Id, Alert = GetEventAlert(snapshot.Entity, applyMigrationMappings: true), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Dqt.CrmIntegrationTests/CrmClientFixture.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Dqt.CrmIntegrationTests/CrmClientFixture.cs index 8285cc908..59cedd5fc 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Dqt.CrmIntegrationTests/CrmClientFixture.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Dqt.CrmIntegrationTests/CrmClientFixture.cs @@ -6,6 +6,7 @@ using Microsoft.Extensions.Caching.Memory; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.Services.TrnGenerationApi; using TeachingRecordSystem.TestCommon; @@ -18,10 +19,11 @@ public sealed class CrmClientFixture : IDisposable private readonly CancellationTokenSource _completedCts; private readonly EnvironmentLockManager _lockManager; private readonly IMemoryCache _memoryCache; + private readonly ILoggerFactory _loggerFactory; private readonly ITrnGenerationApiClient _trnGenerationApiClient; private readonly ReferenceDataCache _referenceDataCache; - public CrmClientFixture(ServiceClient serviceClient, DbFixture dbFixture, IConfiguration configuration, IMemoryCache memoryCache) + public CrmClientFixture(ServiceClient serviceClient, DbFixture dbFixture, IConfiguration configuration, IMemoryCache memoryCache, ILoggerFactory loggerFactory) { Clock = new Clock(); Configuration = configuration; @@ -31,6 +33,7 @@ public CrmClientFixture(ServiceClient serviceClient, DbFixture dbFixture, IConfi _lockManager = new EnvironmentLockManager(Configuration); _lockManager.AcquireLock(_completedCts.Token); _memoryCache = memoryCache; + _loggerFactory = loggerFactory; _trnGenerationApiClient = GetTrnGenerationApiClient(); _referenceDataCache = new ReferenceDataCache( new CrmQueryDispatcher(CreateQueryServiceProvider(_baseServiceClient, referenceDataCache: null), serviceClientName: null), @@ -65,7 +68,7 @@ public TestDataScope CreateTestDataScope(bool withSync = false) _referenceDataCache, Clock, () => _trnGenerationApiClient.GenerateTrnAsync(), - withSync ? TestDataSyncConfiguration.Sync(new(DbFixture.GetDataSource(), orgService, _referenceDataCache, Clock)) : TestDataSyncConfiguration.NoSync()), + withSync ? TestDataSyncConfiguration.Sync(new(DbFixture.GetDataSource(), orgService, _referenceDataCache, Clock, _loggerFactory)) : TestDataSyncConfiguration.NoSync()), _memoryCache, onAsyncDispose); } diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/ApiSchema/EventMapperTestBase.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/ApiSchema/EventMapperTestBase.cs index 94dff2794..20645935d 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/ApiSchema/EventMapperTestBase.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/ApiSchema/EventMapperTestBase.cs @@ -1,4 +1,5 @@ using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.Dqt; using TeachingRecordSystem.Core.Services.TrsDataSync; @@ -30,7 +31,8 @@ public EventMapperFixture( IOrganizationServiceAsync2 organizationService, ICrmQueryDispatcher crmQueryDispatcher, FakeTrnGenerator trnGenerator, - IServiceProvider serviceProvider) + IServiceProvider serviceProvider, + ILoggerFactory loggerFactory) { Clock = new TestableClock(); DbFixture = dbFixture; @@ -40,7 +42,8 @@ public EventMapperFixture( dbFixture.GetDataSource(), organizationService, ReferenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncAllInductionsFromCrmJobTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncAllInductionsFromCrmJobTests.cs index 93054a950..f42e48113 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncAllInductionsFromCrmJobTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncAllInductionsFromCrmJobTests.cs @@ -39,7 +39,8 @@ public async Task SyncInductionsAsync_WithExistingDqtInduction_UpdatesPersonReco var job = new SyncAllInductionsFromCrmJob( CrmServiceClientProvider, Helper, - options); + options, + LoggerFactory); await job.ExecuteAsync(createMigratedEvent: false, dryRun: false, CancellationToken.None); diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobFixture.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobFixture.cs index 0676a83b4..ffe611cf3 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobFixture.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobFixture.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.Dqt; using TeachingRecordSystem.Core.Services.TrsDataSync; @@ -10,16 +11,20 @@ public SyncFromCrmJobFixture( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; + LoggerFactory = loggerFactory; Clock = new(); + LoggerFactory = loggerFactory; Helper = new TrsDataSyncHelper( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), @@ -36,6 +41,8 @@ public SyncFromCrmJobFixture( public DbFixture DbFixture { get; } + public ILoggerFactory LoggerFactory { get; } + public TrsDataSyncHelper Helper { get; } public TestData TestData { get; } @@ -44,7 +51,7 @@ public SyncFromCrmJobFixture( Task IAsyncLifetime.DisposeAsync() => Task.CompletedTask; - Task IAsyncLifetime.InitializeAsync() => DbFixture.DbHelper.ClearDataAsync(); + Task IAsyncLifetime.InitializeAsync() => Task.CompletedTask; private class TestCrmServiceClientProvider : ICrmServiceClientProvider { diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobTestBase.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobTestBase.cs index f8b259229..32fbf4257 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobTestBase.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Jobs/SyncFromCrmJobTestBase.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using TeachingRecordSystem.Core.Dqt; using TeachingRecordSystem.Core.Services.TrsDataSync; @@ -14,6 +15,8 @@ public SyncFromCrmJobTestBase(SyncFromCrmJobFixture jobFixture) protected TestableClock Clock => JobFixture.Clock; + protected ILoggerFactory LoggerFactory => JobFixture.LoggerFactory; + protected DbFixture DbFixture => JobFixture.DbFixture; protected TrsDataSyncHelper Helper => JobFixture.Helper; diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/DqtOutbox/OutboxMessageHandlerTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/DqtOutbox/OutboxMessageHandlerTests.cs index c05544490..4b013d65f 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/DqtOutbox/OutboxMessageHandlerTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/DqtOutbox/OutboxMessageHandlerTests.cs @@ -1,4 +1,5 @@ using Microsoft.Extensions.DependencyInjection; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.DataStore.Postgres; using TeachingRecordSystem.Core.Dqt; @@ -87,7 +88,8 @@ public OutboxMessageHandlerFixture( IOrganizationServiceAsync2 organizationService, IDbContextFactory dbContextFactory, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { Clock = new TestableClock(); DbFixture = dbFixture; @@ -97,7 +99,8 @@ public OutboxMessageHandlerFixture( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Gias/EstablishmentRefresherTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Gias/EstablishmentRefresherTests.cs index df38f69fe..4744dd3a8 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Gias/EstablishmentRefresherTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Gias/EstablishmentRefresherTests.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.Services.Establishments.Gias; using TeachingRecordSystem.Core.Services.TrsDataSync; @@ -11,7 +12,8 @@ public EstablishmentRefresherTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -20,7 +22,8 @@ public EstablishmentRefresherTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Tps/TpsEstablishmentRefresherTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Tps/TpsEstablishmentRefresherTests.cs index 810c3bdbe..2df7f2dbb 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Tps/TpsEstablishmentRefresherTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/Establishments/Tps/TpsEstablishmentRefresherTests.cs @@ -1,4 +1,5 @@ using System.Text; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.DataStore.Postgres.Models; using TeachingRecordSystem.Core.Services.Establishments.Tps; @@ -28,7 +29,8 @@ public TpsEstablishmentRefresherTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -37,7 +39,8 @@ public TpsEstablishmentRefresherTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/PersonMatching/PersonMatchingServiceTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/PersonMatching/PersonMatchingServiceTests.cs index 37cdb23f1..e1349f98a 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/PersonMatching/PersonMatchingServiceTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/PersonMatching/PersonMatchingServiceTests.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.DataStore.Postgres.Models; using TeachingRecordSystem.Core.Services.PersonMatching; @@ -12,7 +13,8 @@ public PersonMatchingServiceTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -21,7 +23,8 @@ public PersonMatchingServiceTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.Induction.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.Induction.cs index 719541b5b..d0aaf3d97 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.Induction.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.Induction.cs @@ -717,7 +717,7 @@ private Task GetEventsForInduction(Guid inductionId) => FROM events as e WHERE (e.payload -> 'Induction' ->> 'InductionId')::uuid = {inductionId} OR (e.payload -> 'DqtInduction' ->> 'InductionId')::uuid = {inductionId} - ORDER BY e.created + ORDER BY e.created, (CASE WHEN e.event_name = 'InductionMigratedEvent' THEN 1 ELSE 0 END) """).ToArrayAsync(); return results.Select(r => EventBase.Deserialize(r.Payload, r.EventName)).ToArray(); diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.cs index 671a8fa3d..3fcca22a2 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncHelperTests.cs @@ -1,5 +1,6 @@ using FakeXrmEasy.Extensions; using Microsoft.Crm.Sdk.Messages; +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using Microsoft.Xrm.Sdk; using TeachingRecordSystem.Core.Dqt.Models; @@ -14,7 +15,8 @@ public TrsDataSyncHelperTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -23,7 +25,8 @@ public TrsDataSyncHelperTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncServiceFixture.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncServiceFixture.cs index 4b1af1e4a..ea5c2b6ed 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncServiceFixture.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/TrsDataSync/TrsDataSyncServiceFixture.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using Microsoft.Extensions.Logging.Abstractions; using Microsoft.Extensions.Options; using Microsoft.PowerPlatform.Dataverse.Client; @@ -12,7 +13,8 @@ public TrsDataSyncServiceFixture( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -21,7 +23,8 @@ public TrsDataSyncServiceFixture( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/TpsCsvExtractProcessorTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/TpsCsvExtractProcessorTests.cs index f88fef40c..3ecd91eb9 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/TpsCsvExtractProcessorTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/TpsCsvExtractProcessorTests.cs @@ -1,3 +1,4 @@ +using Microsoft.Extensions.Logging; using Microsoft.PowerPlatform.Dataverse.Client; using TeachingRecordSystem.Core.DataStore.Postgres.Models; using TeachingRecordSystem.Core.Services.TrsDataSync; @@ -12,7 +13,8 @@ public TpsCsvExtractProcessorTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -21,7 +23,8 @@ public TpsCsvExtractProcessorTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(), diff --git a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/WorkforceDataExporterTests.cs b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/WorkforceDataExporterTests.cs index 428aba7ca..486f49b15 100644 --- a/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/WorkforceDataExporterTests.cs +++ b/TeachingRecordSystem/tests/TeachingRecordSystem.Core.Tests/Services/WorkforceData/WorkforceDataExporterTests.cs @@ -1,5 +1,6 @@ using Google.Apis.Upload; using Google.Cloud.Storage.V1; +using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Microsoft.PowerPlatform.Dataverse.Client; using Parquet.Serialization; @@ -16,7 +17,8 @@ public WorkforceDataExporterTests( DbFixture dbFixture, IOrganizationServiceAsync2 organizationService, ReferenceDataCache referenceDataCache, - FakeTrnGenerator trnGenerator) + FakeTrnGenerator trnGenerator, + ILoggerFactory loggerFactory) { DbFixture = dbFixture; Clock = new(); @@ -25,7 +27,8 @@ public WorkforceDataExporterTests( dbFixture.GetDataSource(), organizationService, referenceDataCache, - Clock); + Clock, + loggerFactory); TestData = new TestData( dbFixture.GetDbContextFactory(),