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

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

            //Load
            int loaded = await _patientArtLoader.Load(request.Extract.Id, found);

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


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


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

            return(true);
        }
Example #2
0
 public void SetUp()
 {
     _loader    = TestInitializer.ServiceProvider.GetService <IPatientArtLoader>();
     _extractor = TestInitializer.ServiceProvider.GetService <IPatientArtSourceExtractor>();
     _extract   = _extracts.First(x => x.Name.IsSameAs(nameof(PatientArtExtract)));
     _count     = _extractor.Extract(_extract, _protocol).Result;
 }
        public void should_Extract(string name)
        {
            Assert.False(_extractsContext.TempPatientArtExtracts.Any());
            var extract = _extracts.First(x => x.Name.IsSameAs(name));
            var count   = _extractor.Extract(extract, _protocol).Result;

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