Skip to content

Commit

Permalink
[dagster-azure] delete blobs after test in integration tests
Browse files Browse the repository at this point in the history
  • Loading branch information
dpeng817 committed Dec 30, 2024
1 parent 020deb3 commit 02f06c7
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 22 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ def build_dagster_oss_nightly_steps() -> List[BuildkiteStep]:
"TEST_AZURE_CLIENT_SECRET",
"TEST_AZURE_STORAGE_ACCOUNT_ID",
"TEST_AZURE_CONTAINER_ID",
"TEST_AZURE_ACCESS_KEY",
],
always_run_if=lambda: True,
),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,7 @@ def build_azure_live_test_suite_steps() -> List[BuildkiteTopLevelStep]:
"TEST_AZURE_CLIENT_SECRET",
"TEST_AZURE_STORAGE_ACCOUNT_ID",
"TEST_AZURE_CONTAINER_ID",
"TEST_AZURE_ACCESS_KEY",
],
).build_steps()

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,12 @@

import pytest
import requests
from azure.identity import ClientSecretCredential
from azure.storage.blob import ContainerClient
from dagster._core.test_utils import environ
from dagster._time import get_current_timestamp
from dagster._utils import process_is_alive
from dagster_azure.blob.utils import create_blob_client


def integration_test_dir() -> Path:
Expand All @@ -32,6 +35,12 @@ def path_to_dagster_yamls() -> Path:
return Path(__file__).parent / "dagster-yamls"


def delete_blobs_with_prefix(prefix: str) -> None:
container_client = get_container_client(get_credentials())
for blob in container_client.list_blobs(name_starts_with=prefix):
container_client.delete_blob(blob.name)


@pytest.fixture(name="dagster_yaml")
def dagster_yaml_path(request) -> Generator[Path, None, None]:
additional_env_vars = {}
Expand All @@ -58,8 +67,11 @@ def setup_dagster_home(dagster_yaml: Path) -> Generator[str, None, None]:
@pytest.fixture
def prefix_env() -> Generator[str, None, None]:
prefix = f"prefix_{uuid.uuid4().hex}"
with environ({"TEST_AZURE_LOG_PREFIX": prefix}):
yield prefix
try:
with environ({"TEST_AZURE_LOG_PREFIX": prefix}):
yield prefix
finally:
delete_blobs_with_prefix(prefix)


@pytest.fixture(name="dagster_dev")
Expand Down Expand Up @@ -95,3 +107,28 @@ def stand_up_dagster(
finally:
if process_is_alive(process.pid):
os.killpg(process.pid, signal.SIGKILL)


def get_credentials() -> ClientSecretCredential:
return ClientSecretCredential(
tenant_id=os.environ["TEST_AZURE_TENANT_ID"],
client_id=os.environ["TEST_AZURE_CLIENT_ID"],
client_secret=os.environ["TEST_AZURE_CLIENT_SECRET"],
)


def get_container_client(credentials: ClientSecretCredential) -> ContainerClient:
return create_blob_client(
storage_account="chriscomplogmngr",
credential=credentials,
).get_container_client("mycontainer")


@pytest.fixture(name="credentials")
def setup_credentials() -> Generator[ClientSecretCredential, None, None]:
yield get_credentials()


@pytest.fixture(name="container_client")
def setup_container_client() -> Generator[ContainerClient, None, None]:
yield get_container_client(get_credentials())
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
import os
import subprocess
from pathlib import Path
from typing import Generator

import pytest
from azure.identity import ClientSecretCredential
Expand All @@ -12,24 +10,6 @@
EventRecordsFilter,
_check as check,
)
from dagster_azure.blob.utils import create_blob_client


@pytest.fixture
def credentials() -> ClientSecretCredential:
return ClientSecretCredential(
tenant_id=os.environ["TEST_AZURE_TENANT_ID"],
client_id=os.environ["TEST_AZURE_CLIENT_ID"],
client_secret=os.environ["TEST_AZURE_CLIENT_SECRET"],
)


@pytest.fixture
def container_client(credentials: ClientSecretCredential) -> Generator[ContainerClient, None, None]:
yield create_blob_client(
storage_account="chriscomplogmngr",
credential=credentials,
).get_container_client("mycontainer")


@pytest.mark.parametrize(
Expand Down

0 comments on commit 02f06c7

Please sign in to comment.