async def to_data(instance: 'CdmLocalEntityDeclarationDefinition', res_opt: 'ResolveOptions', options: 'CopyOptions', ctx: 'CdmCorpusContext') -> 'LocalEntity': # Fetch the document from entity schema. entity = await DocumentPersistence.to_data(instance.entity_path, res_opt, options, ctx) if not entity: return None entity.description = instance.explanation entity.lastFileStatusCheckTime = utils.get_formatted_date_string(instance.last_file_status_check_time) entity.lastFileModifiedTime = utils.get_formatted_date_string(instance.last_file_modified_time) entity.lastChildFileModifiedTime = utils.get_formatted_date_string(instance.last_child_file_modified_time) t2pm = TraitToPropertyMap(instance) # Find the trait containing the schema info. schemas = t2pm.fetch_property_value('cdmSchemas') if schemas: entity.schemas = schemas entity.isHidden = bool(t2pm.fetch_trait_reference('is.hidden')) or None if instance.data_partitions: entity.partitions = [] for partition in instance.data_partitions: partiton = await DataPartitionPersistence.to_data(partition, res_opt, options, ctx) if partition: entity.partitions.append(partiton) else: ctx.logger.error('There was an error while trying to convert cdm data partition to model.json partition.') return None return entity
def test_update_and_fetch_list_lookup(self): """Test update and fetch list lookup default value without attributeValue and displayOrder.""" corpus = CdmCorpusDefinition() cdm_attribute = CdmTypeAttributeDefinition(corpus.ctx, 'SomeAttribute') trait_to_property_map = TraitToPropertyMap(cdm_attribute) constant_values = [{'languageTag': 'en', 'displayText': 'Fax'}] trait_to_property_map.update_property_value('defaultValue', constant_values) result = trait_to_property_map.fetch_property_value('defaultValue') self.assertEqual(1, len(result)) self.assertEqual('en', result[0].get('languageTag')) self.assertEqual('Fax', result[0].get('displayText')) self.assertIsNone(result[0].get('attributeValue')) self.assertIsNone(result[0].get('displayOrder'))
class CdmDataPartitionDefinition(CdmObjectDefinition, CdmFileStatus): def __init__(self, ctx: 'CdmCorpusContext', name: str) -> None: super().__init__(ctx) # The name of a data partition. self.name = name # type: str # The corpus path for the data file location. self.location = None # type: Optional[str] # Indicates whether this partition is inferred. self.inferred = False # type: bool # The list of key value pairs to give names for the replacement values from the RegEx. self.arguments = {} # type: Dict[str, List[str]] # The path of a specialized schema to use specifically for the partitions generated. self.specialized_schema = None # type: Optional[str] # The refresh time of the partition. self.refresh_time = None # type: Optional[datetime] self.last_child_file_modified_time = None # type: Optional[datetime] self.last_file_modified_time = None # type: Optional[datetime] self.last_file_status_check_time = None # type: Optional[datetime] # --- Internal --- self._ttpm = TraitToPropertyMap(self) @property def object_type(self) -> 'CdmObjectType': return CdmObjectType.DATA_PARTITION_DEF @property def description(self) -> str: return cast(str, self._ttpm.fetch_property_value('description')) @description.setter def description(self, val: str) -> None: self._ttpm.update_property_value('description', val) def copy( self, res_opt: Optional['ResolveOptions'] = None, host: Optional['CdmDataPartitionDefinition'] = None ) -> 'CdmDataPartitionDefinition': if not res_opt: res_opt = ResolveOptions(wrt_doc=self) if not host: copy = CdmDataPartitionDefinition(self.ctx, self.name) else: copy = host copy.ctx = self.ctx copy.name = self.name copy.description = self.description copy.location = self.location copy.last_file_status_check_time = self.last_file_status_check_time copy.last_file_modified_time = self.last_file_modified_time copy.inferred = self.inferred copy.arguments = self.arguments copy.specialized_schema = self.specialized_schema self._copy_def(res_opt, copy) return copy async def file_status_check_async(self) -> None: """Check the modified time for this object and any children.""" namespace = self.in_document.namespace full_path = self.location if ':' in self.location else (namespace + ':' + self.location) modified_time = await ( cast('CdmCorpusDefinition', self.ctx.corpus) )._fetch_last_modified_time_from_partition_path_async(full_path) # Update modified times. self.last_file_modified_time = time_utils.max_time( modified_time, self.last_file_modified_time) await self.report_most_recent_time_async(self.last_file_modified_time) def get_name(self) -> str: return self.name def is_derived_from(self, base: str, res_opt: Optional['ResolveOptions'] = None) -> bool: return False async def report_most_recent_time_async(self, child_time: datetime) -> None: """Report most recent modified time (of current or children objects) to the parent object.""" if cast(CdmFileStatus, self.owner).report_most_recent_time_async and child_time: await cast(CdmFileStatus, self.owner).report_most_recent_time_async(child_time) def validate(self) -> bool: return bool(self.location) def visit(self, path_from: str, pre_children: 'VisitCallback', post_children: 'VisitCallback') -> bool: path = '' if self.ctx.corpus.block_declared_path_changes is False: path = self._declared_path if not path: path = '{}{}'.format(path_from, (self.get_name() or 'UNNAMED')) self._declared_path = path if pre_children and pre_children(self, path): return False if self._visit_def(path, pre_children, post_children): return True if post_children and post_children(self, path): return False return False