public async Task <bool> Handle(ExtractCwcVisit request, CancellationToken cancellationToken)
        {
            //Extract
            int found = await _cwcVisitSourceExtractor.Extract(request.Extract, request.DatabaseProtocol);

            //Validate
            await _extractValidator.Validate(request.Extract.Id, found, nameof(CwcVisitExtract), $"{nameof(TempCwcVisitExtract)}s");

            //Load
            int loaded = await _cwcVisitLoader.Load(request.Extract.Id, found, request.DatabaseProtocol.SupportsDifferential);

            int rejected =
                _extractHistoryRepository.ProcessRejected(request.Extract.Id, found - loaded, request.Extract);


            _extractHistoryRepository.ProcessExcluded(request.Extract.Id, rejected, request.Extract);

            //notify loaded
            DomainEvents.Dispatch(
                new MnchExtractActivityNotification(request.Extract.Id, new DwhProgress(
                                                        nameof(CwcVisitExtract),
                                                        nameof(ExtractStatus.Loaded),
                                                        found, loaded, rejected, loaded, 0)));

            return(true);
        }
Beispiel #2
0
        public void should_Load()
        {
            Assert.True(_count > 0);
            Assert.False(_extractsContext.CwcVisitExtracts.Any());

            var count = _loader.Load(_extract.Id, _count, false).Result;

            Assert.True(count > 0);
            _extractsContext = TestInitializer.ServiceProvider.GetService <ExtractsContext>();
            Assert.AreEqual(count, _extractsContext.CwcVisitExtracts.Count());
            Log.Debug($"Temp {_count} Main {_extractsContext.CwcVisitExtracts.Count()}");
        }