1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
# pylint: disable=line-too-long,useless-suppression
import functools
from devtools_testutils import AzureRecordedTestCase, EnvironmentVariableLoader, recorded_by_proxy
from azure.core.credentials import AzureKeyCredential
from azure.core.exceptions import HttpResponseError
from azure.ai.language.conversations.authoring import ConversationAuthoringClient
from azure.ai.language.conversations.authoring.models import (
SwapDeploymentsDetails,
)
ConversationsPreparer = functools.partial(
EnvironmentVariableLoader,
"authoring",
authoring_endpoint="https://Sanitized.cognitiveservices.azure.com/",
authoring_key="fake_key",
)
class TestConversations(AzureRecordedTestCase):
def create_client(self, endpoint, key):
return ConversationAuthoringClient(endpoint, AzureKeyCredential(key))
class TestConversationsSwapDeploymentsSync(TestConversations):
@ConversationsPreparer()
@recorded_by_proxy
def test_swap_deployments(self, authoring_endpoint, authoring_key):
authoring_client = self.create_client(authoring_endpoint, authoring_key)
project_name = "EmailApp"
deployment_name_1 = "staging"
deployment_name_2 = "production"
project_client = authoring_client.get_project_client(project_name)
details = SwapDeploymentsDetails(
first_deployment_name=deployment_name_1,
second_deployment_name=deployment_name_2,
)
# Act: begin swap and wait for completion
poller = project_client.project.begin_swap_deployments(body=details)
try:
poller.result() # completes with None; raises on failure
except HttpResponseError as e:
print(f"Operation failed: {e.message}")
print(e.error)
raise
# Success -> poller completed
print(f"Swap deployments completed. done={poller.done()} status={poller.status()}")
|