2023-04-18 09:22:38 +02:00
|
|
|
# Copyright 2022 Collate
|
2025-04-03 10:39:47 +05:30
|
|
|
# Licensed under the Collate Community License, Version 1.0 (the "License");
|
2023-04-18 09:22:38 +02:00
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
2025-04-03 10:39:47 +05:30
|
|
|
# https://github.com/open-metadata/OpenMetadata/blob/main/ingestion/LICENSE
|
2023-04-18 09:22:38 +02:00
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
"""
|
|
|
|
Test Redash connector with CLI
|
|
|
|
"""
|
|
|
|
from typing import List
|
|
|
|
|
2025-01-09 14:59:49 +05:30
|
|
|
import pytest
|
|
|
|
|
2023-04-18 09:22:38 +02:00
|
|
|
from .common.test_cli_dashboard import CliCommonDashboard
|
|
|
|
|
|
|
|
|
|
|
|
class RedashCliTest(CliCommonDashboard.TestSuite):
|
|
|
|
@staticmethod
|
|
|
|
def get_connector_name() -> str:
|
|
|
|
return "redash"
|
|
|
|
|
|
|
|
def get_includes_dashboards(self) -> List[str]:
|
2024-03-05 16:00:22 +01:00
|
|
|
return [".*Orders.*"]
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def get_excludes_dashboards(self) -> List[str]:
|
2024-03-05 16:00:22 +01:00
|
|
|
return [".*World.*"]
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def get_includes_charts(self) -> List[str]:
|
2024-03-05 16:00:22 +01:00
|
|
|
return [".*Orders.*"]
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def get_excludes_charts(self) -> List[str]:
|
2024-03-05 16:00:22 +01:00
|
|
|
return ["World Query Data"]
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
# Redash do not ingest datamodels
|
|
|
|
def get_includes_datamodels(self) -> List[str]:
|
|
|
|
return []
|
|
|
|
|
|
|
|
# Redash do not ingest datamodels
|
|
|
|
def get_excludes_datamodels(self) -> List[str]:
|
|
|
|
return []
|
|
|
|
|
2023-08-31 15:45:41 +02:00
|
|
|
def expected_dashboards_and_charts(self) -> int:
|
2024-03-05 16:00:22 +01:00
|
|
|
return 9
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def expected_lineage(self) -> int:
|
|
|
|
return 0
|
|
|
|
|
|
|
|
def expected_tags(self) -> int:
|
2024-03-05 16:00:22 +01:00
|
|
|
return 1
|
2023-04-18 09:22:38 +02:00
|
|
|
|
2023-08-31 15:45:41 +02:00
|
|
|
def expected_datamodels(self) -> int:
|
|
|
|
return 0
|
2023-04-18 09:22:38 +02:00
|
|
|
|
2023-08-31 15:45:41 +02:00
|
|
|
def expected_datamodel_lineage(self) -> int:
|
|
|
|
return 0
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def expected_filtered_mix(self) -> int:
|
2024-03-05 16:00:22 +01:00
|
|
|
return 3
|
2023-04-18 09:22:38 +02:00
|
|
|
|
|
|
|
def expected_filtered_sink_mix(self) -> int:
|
2024-06-18 02:46:47 +02:00
|
|
|
return 4
|
2023-12-08 19:55:49 +05:30
|
|
|
|
|
|
|
def expected_dashboards_and_charts_after_patch(self) -> int:
|
2024-02-14 11:03:17 +05:30
|
|
|
return 1
|
2025-01-09 14:59:49 +05:30
|
|
|
|
|
|
|
@pytest.mark.order(11)
|
|
|
|
def test_lineage(self) -> None:
|
|
|
|
pytest.skip("Lineage not configured. Skipping Test")
|