File: get_test_run_metrics.py

package info (click to toggle)
python-azure 20230112%2Bgit-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 749,544 kB
  • sloc: python: 6,815,827; javascript: 287; makefile: 195; xml: 109; sh: 105
file content (71 lines) | stat: -rw-r--r-- 2,348 bytes parent folder | download
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
# -------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License.txt in the project root for
# license information.
# --------------------------------------------------------------------------

"""
FILE: get_test_run_metrics.py

DESCRIPTION:
    This sample shows how to get test run metrics

USAGE:
    python get_test_run_metrics.py

    Set the environment variables with your own values before running the sample:
    1)  AZURE_CLIENT_ID - client id
    2)  AZURE_CLIENT_SECRET - client secret
    3)  AZURE_TENANT_ID - tenant id for your Azure
    4)  LOADTESTSERVICE_ENDPOINT - Data Plane endpoint for Loadtestservice
"""
from azure.developer.loadtesting import LoadTestingClient

# for details refer: https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/loadtestservice/azure-developer
# -loadtesting/README.md
from azure.identity import DefaultAzureCredential

import os
from dotenv import load_dotenv

import time

load_dotenv()
LOADTESTSERVICE_ENDPOINT = os.environ["LOADTESTSERVICE_ENDPOINT"]

TEST_RUN_ID = "my-new-load-test-run"
TEST_ID = "my-new-sdk-test-id"

# Build a client through AAD and resource endpoint
client = LoadTestingClient(credential=DefaultAzureCredential(), endpoint=LOADTESTSERVICE_ENDPOINT)

# checking the test run stats and printing metrics
start_time = time.time()

TIMEOUT = 6000
REFRESH_TIME = 10

# pooling the test run status to get results
while time.time() - start_time < TIMEOUT:
    result = client.load_test_runs.get_test_run(TEST_RUN_ID)
    if result["status"] == "DONE" or result["status"] == "CANCELLED" or result["status"] == "FAILED":
        # getting the test run metrics filters
        client_metrics_filters = client.load_test_runs.get_test_run_client_metrics_filters(
            TEST_RUN_ID
        )

        # getting the test run metrics
        result_metrics = client.load_test_runs.get_test_run_client_metrics(
            TEST_RUN_ID,
            {
                "requestSamplers": ["GET"],
                "startTime": client_metrics_filters['timeRange']['startTime'],
                "endTime": client_metrics_filters['timeRange']['endTime']
            }
        )

        print(result_metrics)
        break

    else:
        time.sleep(REFRESH_TIME)