mirror of
https://github.com/microsoft/onefuzz.git
synced 2025-06-16 11:58:09 +00:00
handle error condition when creating a container that is being deleted (#582)
When users try to create a container immediately after deleting it, Azure will fail saying the deletion is in-progress. catching ResourceExistsError during create handles this error.
This commit is contained in:
@ -10,7 +10,7 @@ import urllib.parse
|
|||||||
from typing import Dict, Optional, Union, cast
|
from typing import Dict, Optional, Union, cast
|
||||||
|
|
||||||
from azure.common import AzureHttpError, AzureMissingResourceHttpError
|
from azure.common import AzureHttpError, AzureMissingResourceHttpError
|
||||||
from azure.core.exceptions import ResourceNotFoundError
|
from azure.core.exceptions import ResourceExistsError, ResourceNotFoundError
|
||||||
from azure.storage.blob import (
|
from azure.storage.blob import (
|
||||||
BlobClient,
|
BlobClient,
|
||||||
BlobSasPermissions,
|
BlobSasPermissions,
|
||||||
@ -123,7 +123,9 @@ def create_container(
|
|||||||
client = get_blob_service(account).get_container_client(container)
|
client = get_blob_service(account).get_container_client(container)
|
||||||
try:
|
try:
|
||||||
client.create_container(metadata=metadata)
|
client.create_container(metadata=metadata)
|
||||||
except AzureHttpError as err:
|
except (ResourceExistsError, AzureHttpError) as err:
|
||||||
|
# note: resource exists error happens during creation if the container
|
||||||
|
# is being deleted
|
||||||
logging.error(
|
logging.error(
|
||||||
(
|
(
|
||||||
"unable to create container. account: %s "
|
"unable to create container. account: %s "
|
||||||
|
Reference in New Issue
Block a user