2024-07-17 08:11:34 +02:00
|
|
|
import sys
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
from metadata.generated.schema.entity.services.databaseService import DatabaseService
|
|
|
|
from metadata.generated.schema.metadataIngestion.databaseServiceQueryUsagePipeline import (
|
|
|
|
DatabaseUsageConfigType,
|
|
|
|
)
|
|
|
|
from metadata.ingestion.lineage.sql_lineage import search_cache
|
|
|
|
from metadata.workflow.metadata import MetadataWorkflow
|
|
|
|
from metadata.workflow.usage import UsageWorkflow
|
|
|
|
|
|
|
|
if not sys.version_info >= (3, 9):
|
|
|
|
pytest.skip("requires python 3.9+", allow_module_level=True)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture()
|
|
|
|
def usage_config(sink_config, workflow_config, db_service):
|
|
|
|
return {
|
|
|
|
"source": {
|
|
|
|
"type": "postgres-usage",
|
|
|
|
"serviceName": db_service.fullyQualifiedName.root,
|
|
|
|
"sourceConfig": {
|
|
|
|
"config": {"type": DatabaseUsageConfigType.DatabaseUsage.value}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"processor": {"type": "query-parser", "config": {}},
|
|
|
|
"stage": {
|
|
|
|
"type": "table-usage",
|
|
|
|
"config": {
|
|
|
|
"filename": "/tmp/postgres_usage",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"bulkSink": {
|
|
|
|
"type": "metadata-usage",
|
|
|
|
"config": {
|
|
|
|
"filename": "/tmp/postgres_usage",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"sink": sink_config,
|
|
|
|
"workflowConfig": workflow_config,
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-08-20 10:42:10 +02:00
|
|
|
def test_usage(
|
|
|
|
patch_passwords_for_db_services,
|
|
|
|
run_workflow,
|
|
|
|
ingestion_config,
|
|
|
|
usage_config,
|
|
|
|
metadata,
|
|
|
|
db_service,
|
|
|
|
):
|
2024-07-17 08:11:34 +02:00
|
|
|
search_cache.clear()
|
|
|
|
run_workflow(MetadataWorkflow, ingestion_config)
|
|
|
|
run_workflow(UsageWorkflow, usage_config)
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.xfail(
|
|
|
|
reason="'metadata.ingestion.lineage.sql_lineage.search_cache' gets corrupted with invalid data."
|
|
|
|
" See issue https://github.com/open-metadata/OpenMetadata/issues/16408",
|
|
|
|
strict=True,
|
|
|
|
)
|
|
|
|
def test_usage_delete_usage(
|
2024-08-20 10:42:10 +02:00
|
|
|
patch_passwords_for_db_services,
|
|
|
|
run_workflow,
|
|
|
|
ingestion_config,
|
|
|
|
usage_config,
|
|
|
|
metadata,
|
|
|
|
db_service,
|
2024-07-17 08:11:34 +02:00
|
|
|
):
|
|
|
|
search_cache.clear()
|
|
|
|
run_workflow(MetadataWorkflow, ingestion_config)
|
|
|
|
run_workflow(UsageWorkflow, usage_config)
|
|
|
|
metadata.delete(DatabaseService, db_service.id, hard_delete=True, recursive=True)
|
|
|
|
run_workflow(MetadataWorkflow, ingestion_config)
|
|
|
|
run_workflow(UsageWorkflow, usage_config)
|