public void TestNestedDemandsGetPutIntoDatabaseAndCanBeBroughtBack() { var pipe = new Pipeline(CatalogueRepository, "NestedPipe"); var pc = new PipelineComponent(CatalogueRepository, pipe, typeof(BasicDataReleaseDestination), -1, "Coconuts"); pipe.DestinationPipelineComponent_ID = pc.ID; pipe.SaveToDatabase(); //some of the DemandsInitialization on BasicDataReleaseDestination should be nested var f = new ArgumentFactory(); Assert.True( f.GetRequiredProperties(typeof(BasicDataReleaseDestination)).Any(r => r.ParentPropertyInfo != null)); //new pc should have no arguments Assert.That(pc.GetAllArguments(), Is.Empty); //we create them (the root and nested ones!) var args = pc.CreateArgumentsForClassIfNotExists <BasicDataReleaseDestination>(); //and get all arguments / create arguments for class should have handled that Assert.That(pc.GetAllArguments().Any()); var match = args.Single(a => a.Name == "ReleaseSettings.DeleteFilesOnSuccess"); match.SetValue(true); match.SaveToDatabase(); var useCase = ReleaseUseCase.DesignTime(); var factory = new DataFlowPipelineEngineFactory(useCase, RepositoryLocator.CatalogueRepository.MEF); var destInstance = factory.CreateDestinationIfExists(pipe); Assert.AreEqual(true, ((BasicDataReleaseDestination)destInstance).ReleaseSettings.DeleteFilesOnSuccess); }
public DataExportChildProvider(IRDMPPlatformRepositoryServiceLocator repositoryLocator, IChildProvider[] pluginChildProviders, ICheckNotifier errorsCheckNotifier, DataExportChildProvider previousStateIfKnown) : base(repositoryLocator.CatalogueRepository, pluginChildProviders, errorsCheckNotifier, previousStateIfKnown) { BlackListedSources = previousStateIfKnown?.BlackListedSources ?? new List <ExternalCohortTable>(); _errorsCheckNotifier = errorsCheckNotifier; dataExportRepository = repositoryLocator.DataExportRepository; AllProjectAssociatedCics = GetAllObjects <ProjectCohortIdentificationConfigurationAssociation>(dataExportRepository); _cicAssociations = new HashSet <int>(AllProjectAssociatedCics.Select(a => a.CohortIdentificationConfiguration_ID)); CohortSources = GetAllObjects <ExternalCohortTable>(dataExportRepository); ExtractableDataSets = GetAllObjects <ExtractableDataSet>(dataExportRepository); AddToDictionaries(new HashSet <object>(AllCohortIdentificationConfigurations.Where(cic => _cicAssociations.Contains(cic.ID))), new DescendancyList(AllProjectCohortIdentificationConfigurationsNode)); AddToDictionaries(new HashSet <object>(AllCohortIdentificationConfigurations.Where(cic => !_cicAssociations.Contains(cic.ID))), new DescendancyList(AllFreeCohortIdentificationConfigurationsNode)); _selectedDataSetsWithNoIsExtractionIdentifier = new HashSet <ISelectedDataSets>(dataExportRepository.GetSelectedDatasetsWithNoExtractionIdentifiers()); SelectedDataSets = GetAllObjects <SelectedDataSets>(dataExportRepository); ReportProgress("Fetching data export objects"); var dsDictionary = ExtractableDataSets.ToDictionary(ds => ds.ID, d => d); foreach (SelectedDataSets s in SelectedDataSets) { s.InjectKnown(dsDictionary[s.ExtractableDataSet_ID]); } ReportProgress("Injecting SelectedDataSets"); //This means that the ToString method in ExtractableDataSet doesn't need to go lookup catalogue info var catalogueIdDict = AllCatalogues.ToDictionary(c => c.ID, c2 => c2); foreach (ExtractableDataSet ds in ExtractableDataSets) { if (catalogueIdDict.TryGetValue(ds.Catalogue_ID, out Catalogue cata)) { ds.InjectKnown(cata); } } ReportProgress("Injecting ExtractableDataSet"); AllPackages = GetAllObjects <ExtractableDataSetPackage>(dataExportRepository); Projects = GetAllObjects <Project>(dataExportRepository); ExtractionConfigurations = GetAllObjects <ExtractionConfiguration>(dataExportRepository); ReportProgress("Get Projects and Configurations"); ExtractionConfigurationsByProject = ExtractionConfigurations.GroupBy(k => k.Project_ID).ToDictionary(gdc => gdc.Key, gdc => gdc.ToList()); ReportProgress("Grouping Extractions by Project"); AllGlobalExtractionFilterParameters = GetAllObjects <GlobalExtractionFilterParameter>(dataExportRepository); AllContainers = GetAllObjects <FilterContainer>(dataExportRepository).ToDictionary(o => o.ID, o => o); AllDeployedExtractionFilters = GetAllObjects <DeployedExtractionFilter>(dataExportRepository); _allParameters = GetAllObjects <DeployedExtractionFilterParameter>(dataExportRepository); ReportProgress("Getting Filters"); //if we are using a database repository then we can make use of the caching class DataExportFilterManagerFromChildProvider to speed up //filter contents var dbRepo = dataExportRepository as DataExportRepository; _dataExportFilterManager = dbRepo == null ? dataExportRepository.FilterManager : new DataExportFilterManagerFromChildProvider(dbRepo, this); ReportProgress("Building FilterManager"); Cohorts = GetAllObjects <ExtractableCohort>(dataExportRepository); _cohortsByOriginId = new Dictionary <int, HashSet <ExtractableCohort> >(); foreach (ExtractableCohort c in Cohorts) { if (!_cohortsByOriginId.ContainsKey(c.OriginID)) { _cohortsByOriginId.Add(c.OriginID, new HashSet <ExtractableCohort>()); } _cohortsByOriginId[c.OriginID].Add(c); } _configurationToDatasetMapping = new Dictionary <ExtractionConfiguration, List <SelectedDataSets> >(); ReportProgress("Fetching Cohorts"); GetCohortAvailability(); ReportProgress("GetCohortAvailability"); var configToSds = SelectedDataSets.GroupBy(k => k.ExtractionConfiguration_ID).ToDictionary(gdc => gdc.Key, gdc => gdc.ToList()); foreach (ExtractionConfiguration configuration in ExtractionConfigurations) { if (configToSds.TryGetValue(configuration.ID, out List <SelectedDataSets> result)) { _configurationToDatasetMapping.Add(configuration, result); } } ReportProgress("Mapping configurations to datasets"); RootCohortsNode = new AllCohortsNode(); AddChildren(RootCohortsNode, new DescendancyList(RootCohortsNode)); foreach (ExtractableDataSetPackage package in AllPackages) { AddChildren(package, new DescendancyList(package)); } ReportProgress("Packages and Cohorts"); foreach (Project p in Projects) { AddChildren(p, new DescendancyList(p)); } ReportProgress("Projects"); //work out all the Catalogues that are extractable (Catalogues are extractable if there is an ExtractableDataSet with the Catalogue_ID that matches them) var cataToEds = new Dictionary <int, ExtractableDataSet>(ExtractableDataSets.ToDictionary(k => k.Catalogue_ID)); //inject extractability into Catalogues foreach (Catalogue catalogue in AllCatalogues) { if (cataToEds.TryGetValue(catalogue.ID, out ExtractableDataSet result)) { catalogue.InjectKnown(result.GetCatalogueExtractabilityStatus()); } else { catalogue.InjectKnown(new CatalogueExtractabilityStatus(false, false)); } } ReportProgress("Catalogue extractability injection"); try { AddPipelineUseCases(new Dictionary <string, PipelineUseCase> { { "File Import", UploadFileUseCase.DesignTime() }, { "Extraction", ExtractionPipelineUseCase.DesignTime() }, { "Release", ReleaseUseCase.DesignTime() }, { "Cohort Creation", CohortCreationRequest.DesignTime() }, { "Caching", CachingPipelineUseCase.DesignTime() }, { "Aggregate Committing", CreateTableFromAggregateUseCase.DesignTime(repositoryLocator.CatalogueRepository) } }); } catch (Exception ex) { _errorsCheckNotifier.OnCheckPerformed(new CheckEventArgs("Failed to build DesignTime PipelineUseCases", CheckResult.Fail, ex)); } ReportProgress("Pipeline adding"); }
public override void SetDatabaseObject(IActivateItems activator, Project databaseObject) { base.SetDatabaseObject(activator, databaseObject); if (!_commonFunctionality.IsSetup) { _commonFunctionality.SetUp(RDMPCollection.None, tlvReleasePotentials, Activator, olvName, null, new RDMPCollectionCommonFunctionalitySettings { AddFavouriteColumn = false, AllowPinning = false, SuppressChildrenAdder = true, AddCheckColumn = false }); } _childProvider = (DataExportChildProvider)Activator.CoreChildProvider; _project = databaseObject; //figure out the globals var ec = _project.ExtractionConfigurations.FirstOrDefault(); _globals = ec != null?ec.GetGlobals() : new IMapsDirectlyToDatabaseTable[0]; if (_pipelineSelectionUI1 == null) { var context = ReleaseUseCase.DesignTime(); _pipelineSelectionUI1 = new PipelineSelectionUIFactory(Activator.RepositoryLocator.CatalogueRepository, null, context).Create(Activator, "Release", DockStyle.Fill); _pipelineSelectionUI1.CollapseToSingleLineMode(); _pipelineSelectionUI1.Pipeline = null; _pipelineSelectionUI1.PipelineChanged += ResetChecksUI; _pipelinePanel = new ToolStripControlHost((Control)_pipelineSelectionUI1); } CommonFunctionality.Add(new ToolStripLabel("Release Pipeline:")); CommonFunctionality.Add(_pipelinePanel); CommonFunctionality.AddHelpStringToToolStrip("Release Pipeline", "The sequence of components that will be executed in order to gather the extracted artifacts and assemble them into a single release folder/database. This will start with a source component that gathers the artifacts (from wherever they were extracted to) followed by subsequent components (if any) and then a destination component that generates the final releasable file/folder."); checkAndExecuteUI1.SetItemActivator(activator); var checkedBefore = tlvReleasePotentials.CheckedObjects; tlvReleasePotentials.ClearObjects(); tlvReleasePotentials.AddObject(_globalsNode); tlvReleasePotentials.AddObject(_project); tlvReleasePotentials.ExpandAll(); if (_isFirstTime) { tlvReleasePotentials.CheckAll(); } else if (checkedBefore.Count > 0) { tlvReleasePotentials.CheckObjects(checkedBefore); } _isFirstTime = false; tlvReleasePotentials.DisableObjects(_globals); //tlvReleasePotentials.DisableObject(_globalsNode); }