From ab7dd90ef49056b0a59865e722539e6e6ea88917 Mon Sep 17 00:00:00 2001 From: Steinthor Palsson Date: Thu, 16 May 2024 19:32:33 -0400 Subject: [PATCH] Test resolved fsspec instance --- .../configuration/specs/azure_credentials.py | 4 ---- tests/load/filesystem/test_azure_credentials.py | 15 ++++++++++++++- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/dlt/common/configuration/specs/azure_credentials.py b/dlt/common/configuration/specs/azure_credentials.py index 96119206c3..8b8fc259f2 100644 --- a/dlt/common/configuration/specs/azure_credentials.py +++ b/dlt/common/configuration/specs/azure_credentials.py @@ -7,10 +7,6 @@ CredentialsWithDefault, configspec, ) -from dlt.common.configuration.specs.exceptions import InvalidBoto3Session -from dlt import version - -import fsspec @configspec diff --git a/tests/load/filesystem/test_azure_credentials.py b/tests/load/filesystem/test_azure_credentials.py index 194d6db33d..885c6aba4f 100644 --- a/tests/load/filesystem/test_azure_credentials.py +++ b/tests/load/filesystem/test_azure_credentials.py @@ -1,5 +1,6 @@ from typing import Dict from urllib.parse import parse_qs +from uuid import uuid4 import pytest @@ -15,6 +16,7 @@ from tests.load.utils import ALL_FILESYSTEM_DRIVERS from tests.common.configuration.utils import environment from tests.utils import preserve_environ, autouse_test_storage +from dlt.common.storages.fsspec_filesystem import fsspec_from_config # mark all tests as essential, do not remove pytestmark = pytest.mark.essential @@ -130,7 +132,7 @@ def test_azure_filesystem_configuration_service_principal(environment: Dict[str, environment["CREDENTIALS__AZURE_STORAGE_ACCOUNT_NAME"] = "fake_account_name" environment["CREDENTIALS__AZURE_CLIENT_ID"] = "fake_client_id" environment["CREDENTIALS__AZURE_CLIENT_SECRET"] = "asdsadas" - environment["CREDENTIALS__AZURE_TENANT_ID"] = "fake_tenant_id" + environment["CREDENTIALS__AZURE_TENANT_ID"] = str(uuid4()) config = FilesystemConfiguration(bucket_url="az://my-bucket") @@ -138,6 +140,12 @@ def test_azure_filesystem_configuration_service_principal(environment: Dict[str, assert isinstance(resolved_config.credentials, AzureServicePrincipalCredentialsWithoutDefaults) + fs, bucket = fsspec_from_config(resolved_config) + + assert fs.tenant_id == environment["CREDENTIALS__AZURE_TENANT_ID"] + assert fs.client_id == environment["CREDENTIALS__AZURE_CLIENT_ID"] + assert fs.client_secret == environment["CREDENTIALS__AZURE_CLIENT_SECRET"] + def test_azure_filesystem_configuration_sas_token(environment: Dict[str, str]) -> None: environment["CREDENTIALS__AZURE_STORAGE_ACCOUNT_NAME"] = "fake_account_name" @@ -150,3 +158,8 @@ def test_azure_filesystem_configuration_sas_token(environment: Dict[str, str]) - resolved_config = resolve_configuration(config) assert isinstance(resolved_config.credentials, AzureCredentialsWithoutDefaults) + + fs, bucket = fsspec_from_config(resolved_config) + + assert fs.sas_token == "?" + environment["CREDENTIALS__AZURE_STORAGE_SAS_TOKEN"] + assert fs.account_name == environment["CREDENTIALS__AZURE_STORAGE_ACCOUNT_NAME"]