mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-26 08:25:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import unittest.mock
 | |
| 
 | |
| import pytest
 | |
| 
 | |
| from datahub.ingestion.api.common import PipelineContext
 | |
| from datahub.ingestion.source.sql.oracle import OracleConfig, OracleSource
 | |
| 
 | |
| 
 | |
| def test_oracle_config():
 | |
|     base_config = {
 | |
|         "username": "user",
 | |
|         "password": "password",
 | |
|         "host_port": "host:1521",
 | |
|     }
 | |
| 
 | |
|     config = OracleConfig.parse_obj(
 | |
|         {
 | |
|             **base_config,
 | |
|             "service_name": "svc01",
 | |
|         }
 | |
|     )
 | |
|     assert (
 | |
|         config.get_sql_alchemy_url()
 | |
|         == "oracle+cx_oracle://user:password@host:1521/?service_name=svc01"
 | |
|     )
 | |
| 
 | |
|     with pytest.raises(ValueError):
 | |
|         config = OracleConfig.parse_obj(
 | |
|             {
 | |
|                 **base_config,
 | |
|                 "database": "db",
 | |
|                 "service_name": "svc01",
 | |
|             }
 | |
|         )
 | |
| 
 | |
|     with unittest.mock.patch(
 | |
|         "datahub.ingestion.source.sql.sql_common.SQLAlchemySource.get_workunits"
 | |
|     ):
 | |
|         OracleSource.create(
 | |
|             {
 | |
|                 **base_config,
 | |
|                 "service_name": "svc01",
 | |
|             },
 | |
|             PipelineContext("test-oracle-config"),
 | |
|         ).get_workunits()
 | 
