2021-02-03 17:37:09 -08:00
|
|
|
import subprocess
|
2021-04-13 17:30:24 -07:00
|
|
|
import time
|
2021-02-03 17:37:09 -08:00
|
|
|
|
2021-04-01 12:15:05 -07:00
|
|
|
import pytest
|
2021-02-18 14:47:49 -08:00
|
|
|
from click.testing import CliRunner
|
2021-02-03 17:37:09 -08:00
|
|
|
|
2021-02-18 14:47:49 -08:00
|
|
|
from datahub.entrypoints import datahub
|
2021-04-13 17:30:24 -07:00
|
|
|
from tests.test_helpers import fs_helpers, mce_helpers
|
2021-07-30 17:41:03 -07:00
|
|
|
from tests.test_helpers.click_helpers import assert_result_ok
|
2021-04-13 17:30:24 -07:00
|
|
|
from tests.test_helpers.docker_helpers import wait_for_port
|
2021-02-18 14:47:49 -08:00
|
|
|
|
|
|
|
|
2021-07-14 20:02:48 -07:00
|
|
|
@pytest.mark.integration
|
2021-04-13 17:30:24 -07:00
|
|
|
def test_mssql_ingest(docker_compose_runner, pytestconfig, tmp_path, mock_time):
|
2021-02-18 14:47:49 -08:00
|
|
|
test_resources_dir = pytestconfig.rootpath / "tests/integration/sql_server"
|
|
|
|
|
2021-04-13 17:30:24 -07:00
|
|
|
with docker_compose_runner(
|
|
|
|
test_resources_dir / "docker-compose.yml", "sql-server"
|
|
|
|
) as docker_services:
|
|
|
|
# Wait for SQL Server to be ready. We wait an extra couple seconds, as the port being available
|
|
|
|
# does not mean the server is accepting connections.
|
|
|
|
# TODO: find a better way to check for liveness.
|
|
|
|
wait_for_port(docker_services, "testsqlserver", 1433)
|
|
|
|
time.sleep(5)
|
|
|
|
|
|
|
|
# Run the setup.sql file to populate the database.
|
|
|
|
docker = "docker"
|
|
|
|
command = f"{docker} exec testsqlserver /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P 'test!Password' -d master -i /setup/setup.sql"
|
|
|
|
ret = subprocess.run(
|
|
|
|
command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE
|
|
|
|
)
|
|
|
|
assert ret.returncode == 0
|
|
|
|
|
|
|
|
# Run the metadata ingestion pipeline.
|
|
|
|
config_file = (test_resources_dir / "mssql_to_file.yml").resolve()
|
|
|
|
runner = CliRunner()
|
|
|
|
with fs_helpers.isolated_filesystem(tmp_path):
|
|
|
|
result = runner.invoke(datahub, ["ingest", "-c", f"{config_file}"])
|
2021-07-30 17:41:03 -07:00
|
|
|
assert_result_ok(result)
|
2021-04-13 17:30:24 -07:00
|
|
|
|
2021-06-30 16:53:20 -07:00
|
|
|
# Verify the output.
|
|
|
|
mce_helpers.check_golden_file(
|
|
|
|
pytestconfig,
|
|
|
|
output_path="./mssql_mces.json",
|
|
|
|
golden_path=test_resources_dir / "mssql_mces_golden.json",
|
|
|
|
)
|