mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-20 13:23:52 +00:00 
			
		
		
		
	Aligned airflow source with lineage (#10596)
* aligned airflow source with lineage * fix python test * changes as per comment
This commit is contained in:
		
							parent
							
								
									0e57c56d83
								
							
						
					
					
						commit
						205e5c8c4f
					
				| @ -87,7 +87,8 @@ def parse_xlets(xlet: List[dict]) -> Optional[Dict[str, List[str]]]: | |||||||
|     """ |     """ | ||||||
|     if isinstance(xlet, list) and len(xlet) and isinstance(xlet[0], dict): |     if isinstance(xlet, list) and len(xlet) and isinstance(xlet[0], dict): | ||||||
|         xlet_dict = xlet[0] |         xlet_dict = xlet[0] | ||||||
| 
 |         if isinstance(xlet_dict, dict) and xlet_dict.get("__var"): | ||||||
|  |             xlet_dict = xlet_dict["__var"] | ||||||
|         return { |         return { | ||||||
|             key: value for key, value in xlet_dict.items() if isinstance(value, list) |             key: value for key, value in xlet_dict.items() if isinstance(value, list) | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -44,6 +44,7 @@ from metadata.generated.schema.type.entityReference import EntityReference | |||||||
| from metadata.ingestion.api.source import InvalidSourceException | from metadata.ingestion.api.source import InvalidSourceException | ||||||
| from metadata.ingestion.connections.session import create_and_bind_session | from metadata.ingestion.connections.session import create_and_bind_session | ||||||
| from metadata.ingestion.models.pipeline_status import OMetaPipelineStatus | from metadata.ingestion.models.pipeline_status import OMetaPipelineStatus | ||||||
|  | from metadata.ingestion.source.pipeline.airflow.lineage_parser import get_xlets_from_dag | ||||||
| from metadata.ingestion.source.pipeline.pipeline_service import PipelineServiceSource | from metadata.ingestion.source.pipeline.pipeline_service import PipelineServiceSource | ||||||
| from metadata.utils.helpers import datetime_to_ts | from metadata.utils.helpers import datetime_to_ts | ||||||
| from metadata.utils.logger import ingestion_logger | from metadata.utils.logger import ingestion_logger | ||||||
| @ -408,11 +409,12 @@ class AirflowSource(PipelineServiceSource): | |||||||
|             ) |             ) | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         for task in dag.tasks: |         xlets = get_xlets_from_dag(dag=dag) | ||||||
|             for from_fqn in self.get_inlets(task) or []: |         for xlet in xlets: | ||||||
|  |             for from_fqn in xlet.inlets or []: | ||||||
|                 from_entity = self.metadata.get_by_name(entity=Table, fqn=from_fqn) |                 from_entity = self.metadata.get_by_name(entity=Table, fqn=from_fqn) | ||||||
|                 if from_entity: |                 if from_entity: | ||||||
|                     for to_fqn in self.get_outlets(task) or []: |                     for to_fqn in xlet.outlets or []: | ||||||
|                         to_entity = self.metadata.get_by_name(entity=Table, fqn=to_fqn) |                         to_entity = self.metadata.get_by_name(entity=Table, fqn=to_fqn) | ||||||
|                         if to_entity: |                         if to_entity: | ||||||
|                             lineage = AddLineageRequest( |                             lineage = AddLineageRequest( | ||||||
|  | |||||||
| @ -93,13 +93,13 @@ class TestAirflowLineageParser(TestCase): | |||||||
|             BashOperator( |             BashOperator( | ||||||
|                 task_id="print_date", |                 task_id="print_date", | ||||||
|                 bash_command="date", |                 bash_command="date", | ||||||
|                 inlets={"tables": ["A"]}, |                 inlets={"__var": {"tables": ["A"]}}, | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             BashOperator( |             BashOperator( | ||||||
|                 task_id="sleep", |                 task_id="sleep", | ||||||
|                 bash_command="sleep 1", |                 bash_command="sleep 1", | ||||||
|                 outlets={"tables": ["B"]}, |                 outlets={"__var": {"tables": ["B"]}}, | ||||||
|             ) |             ) | ||||||
| 
 | 
 | ||||||
|             self.assertEqual( |             self.assertEqual( | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 NiharDoshi99
						NiharDoshi99