2025-04-03 10:39:47 +05:30
|
|
|
# Copyright 2025 Collate
|
|
|
|
# Licensed under the Collate Community License, Version 1.0 (the "License");
|
2022-04-07 14:52:50 +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
|
2022-04-07 14:52:50 +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.
|
|
|
|
|
|
|
|
"""
|
|
|
|
OpenMetadata source URL building tests
|
|
|
|
"""
|
2022-04-07 08:52:38 -07:00
|
|
|
from unittest import TestCase
|
2022-04-07 14:52:50 +02:00
|
|
|
|
2023-06-16 13:18:12 +05:30
|
|
|
from metadata.generated.schema.entity.services.connections.database.common.basicAuth import (
|
|
|
|
BasicAuth,
|
|
|
|
)
|
2023-03-30 09:51:21 +02:00
|
|
|
from metadata.generated.schema.entity.services.connections.database.mssqlConnection import (
|
|
|
|
MssqlConnection,
|
|
|
|
MssqlScheme,
|
|
|
|
)
|
2022-04-07 14:52:50 +02:00
|
|
|
from metadata.generated.schema.entity.services.connections.database.mysqlConnection import (
|
|
|
|
MysqlConnection,
|
|
|
|
)
|
2022-04-07 08:52:38 -07:00
|
|
|
from metadata.generated.schema.entity.services.connections.database.redshiftConnection import (
|
|
|
|
RedshiftConnection,
|
|
|
|
)
|
2023-01-02 13:52:27 +01:00
|
|
|
from metadata.ingestion.connections.builders import get_connection_url_common
|
2022-04-07 14:52:50 +02:00
|
|
|
|
|
|
|
|
2022-04-07 08:52:38 -07:00
|
|
|
class TestConfig(TestCase):
|
|
|
|
def test_mysql_url(self):
|
|
|
|
"""
|
|
|
|
Validate MySQL URL building
|
|
|
|
"""
|
|
|
|
connection = MysqlConnection(
|
|
|
|
username="username",
|
2023-06-16 13:18:12 +05:30
|
|
|
authType=BasicAuth(password="password"),
|
2022-04-07 08:52:38 -07:00
|
|
|
hostPort="localhost:1234",
|
|
|
|
)
|
2023-01-02 13:52:27 +01:00
|
|
|
url = get_connection_url_common(connection)
|
2022-04-07 08:52:38 -07:00
|
|
|
assert url == "mysql+pymysql://username:password@localhost:1234"
|
|
|
|
|
|
|
|
def test_redshift_url(self):
|
|
|
|
"""
|
|
|
|
Validate Redshift URL building
|
|
|
|
"""
|
|
|
|
connection = RedshiftConnection(
|
|
|
|
username="username",
|
|
|
|
password="password",
|
|
|
|
hostPort="localhost:1234",
|
|
|
|
database="dev",
|
|
|
|
)
|
2023-01-02 13:52:27 +01:00
|
|
|
url = get_connection_url_common(connection)
|
2022-04-07 08:52:38 -07:00
|
|
|
assert url == "redshift+psycopg2://username:password@localhost:1234/dev"
|
2023-03-30 09:51:21 +02:00
|
|
|
|
|
|
|
def test_mssql_url(self):
|
|
|
|
"""
|
|
|
|
Validate URL building for MSSQL
|
|
|
|
"""
|
|
|
|
from metadata.ingestion.source.database.mssql.connection import (
|
|
|
|
get_connection_url,
|
|
|
|
)
|
|
|
|
|
2023-07-26 10:43:24 +05:30
|
|
|
expected_url = "mssql+pytds://sa:password@james\\bond:1433/master"
|
2023-03-30 09:51:21 +02:00
|
|
|
mssql_conn_obj = MssqlConnection(
|
|
|
|
username="sa",
|
|
|
|
password="password",
|
|
|
|
hostPort="james\\bond:1433",
|
|
|
|
scheme=MssqlScheme.mssql_pytds,
|
2023-07-26 10:43:24 +05:30
|
|
|
database="master",
|
2023-03-30 09:51:21 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
assert expected_url == get_connection_url(mssql_conn_obj)
|