File: test_configuration.py

package info (click to toggle)
python-azure 20250603%2Bgit-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 851,724 kB
  • sloc: python: 7,362,925; ansic: 804; javascript: 287; makefile: 195; sh: 145; xml: 109
file content (80 lines) | stat: -rw-r--r-- 3,639 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
72
73
74
75
76
77
78
79
80
# ------------------------------------
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT License.
# ------------------------------------
from devtools_testutils import AzureRecordedTestCase, recorded_by_proxy
import personalizer_helpers
import time


def configuration_equals(actual, expected):
    assert actual.get("modelExportFrequency") == expected.get("modelExportFrequency")
    assert actual.get("defaultReward") == expected.get("defaultReward")
    assert actual.get("modelRetrainDays") == expected.get("modelRetrainDays")
    assert actual.get("rewardWaitTime") == expected.get("rewardWaitTime")
    assert actual.get("explorationPercentage") == expected.get("explorationPercentage")
    assert actual.get("logRetentionDays") == expected.get("logRetentionDays")


def policy_equals(actual, expected):
    assert actual.get("arguments") == expected.get("arguments")


class TestConfiguration(AzureRecordedTestCase):
    @personalizer_helpers.PersonalizerPreparer()
    @recorded_by_proxy
    def test_update_configuration(self, **kwargs):
        personalizer_endpoint = kwargs.pop("personalizer_endpoint_single_slot")
        personalizer_api_key = kwargs.pop("personalizer_api_key_single_slot")
        client = personalizer_helpers.create_personalizer_admin_client(personalizer_endpoint, personalizer_api_key)
        configuration = {
            "rewardAggregation": "average",
            "modelExportFrequency": "PT3M",
            "defaultReward": 1.0,
            "modelRetrainDays": 2,
            "rewardWaitTime": "PT4H",
            "explorationPercentage": 0.3,
            "logRetentionDays": -1,
            "learningMode": "Online",
        }
        updated_configuration = client.update_service_configuration(configuration)
        configuration_equals(configuration, updated_configuration)
        self.sleep(30)
        new_configuration = client.get_service_configuration()
        configuration_equals(new_configuration, configuration)

    @personalizer_helpers.PersonalizerPreparer()
    @recorded_by_proxy
    def test_update_policy(self, **kwargs):
        personalizer_endpoint = kwargs.pop("personalizer_endpoint_single_slot")
        personalizer_api_key = kwargs.pop("personalizer_api_key_single_slot")
        client = personalizer_helpers.create_personalizer_admin_client(personalizer_endpoint, personalizer_api_key)
        policy = {
            "name": "app1",
            "arguments": "--cb_explore_adf --quadratic GT --quadratic MR --quadratic GR --quadratic ME --quadratic OT "
            "--quadratic OE --quadratic OR --quadratic MS --quadratic GX --ignore A --cb_type ips "
            "--epsilon 0.2",
        }
        updated_policy = client.update_policy(policy)
        self.sleep(30)
        policy_equals(updated_policy, policy)
        new_policy = client.get_policy()
        policy_equals(new_policy, policy)

    @personalizer_helpers.PersonalizerPreparer()
    @recorded_by_proxy
    def test_reset_policy(self, **kwargs):
        default_policy = {
            "name": "app1",
            "arguments": "--cb_explore_adf --epsilon 0.2 --power_t 0 -l 0.001 --cb_type mtr -q ::",
        }
        personalizer_endpoint = kwargs.pop("personalizer_endpoint_single_slot")
        personalizer_api_key = kwargs.pop("personalizer_api_key_single_slot")
        client = personalizer_helpers.create_personalizer_admin_client(personalizer_endpoint, personalizer_api_key)
        new_policy = client.reset_policy()
        self.sleep(30)
        policy_equals(new_policy, default_policy)

    def sleep(self, delay):
        if self.is_live:
            time.sleep(delay)