qontract-reconcile 0.10.2.dev253__py3-none-any.whl → 0.10.2.dev254__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/METADATA +1 -1
- {qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/RECORD +7 -7
- reconcile/aus/base.py +13 -7
- reconcile/aus/models.py +7 -1
- reconcile/utils/ocm/upgrades.py +59 -44
- {qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/WHEEL +0 -0
- {qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/entry_points.txt +0 -0
{qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/METADATA
RENAMED
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: qontract-reconcile
|
3
|
-
Version: 0.10.2.
|
3
|
+
Version: 0.10.2.dev254
|
4
4
|
Summary: Collection of tools to reconcile services with their desired state as defined in the app-interface DB.
|
5
5
|
Project-URL: homepage, https://github.com/app-sre/qontract-reconcile
|
6
6
|
Project-URL: repository, https://github.com/app-sre/qontract-reconcile
|
{qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/RECORD
RENAMED
@@ -117,11 +117,11 @@ reconcile/vpc_peerings_validator.py,sha256=aESqrhm1tpkc2iqSL1UV5to_HjNgjRSffD0cr
|
|
117
117
|
reconcile/aus/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
118
118
|
reconcile/aus/advanced_upgrade_service.py,sha256=lt684trHbKvVDLwwuNVz3Wu_MnytFSbS_7MZTIITh9k,23969
|
119
119
|
reconcile/aus/aus_label_source.py,sha256=o0S2f0qwcII_8nzhHZhRQ83gEZ1DrSXyO4xzSwLebuU,4382
|
120
|
-
reconcile/aus/base.py,sha256=
|
120
|
+
reconcile/aus/base.py,sha256=bMbMJ0KS5J0A9jJky3ZCeU5XHL8jT4UE4X-X_H_rMM4,51465
|
121
121
|
reconcile/aus/cluster_version_data.py,sha256=VZWbUEIbrDKO-sroMpQtiWCTqDraTMd8tssKV0HyTQ0,7140
|
122
122
|
reconcile/aus/healthchecks.py,sha256=jR9c-syh9impnkV0fd6XW3Bnk7iRN5zv8oCRYM-yIRY,2700
|
123
123
|
reconcile/aus/metrics.py,sha256=qh3-oWL8-Hbj1uXgAKonw7sVXGBlPpCyHtVYJusZ9n8,4271
|
124
|
-
reconcile/aus/models.py,sha256=
|
124
|
+
reconcile/aus/models.py,sha256=flK15hzE2wX67yUmNtQsnjOkipQazuV67emeQNyZ1Zo,8591
|
125
125
|
reconcile/aus/node_pool_spec.py,sha256=FkMggklG-4BgQwud2Swp2m3AAAKzZmeaXgohl9uwxZ8,1138
|
126
126
|
reconcile/aus/ocm_addons_upgrade_scheduler_org.py,sha256=PL8QdzWh8lhGneMwSbIYxOp002mJd5gHf_T0Q2cWQho,10350
|
127
127
|
reconcile/aus/ocm_upgrade_scheduler.py,sha256=WPIUUr3n3j-ZtyE3DgsPKzBJ3Dm9i1PSHBRepAf6CF4,3783
|
@@ -736,7 +736,7 @@ reconcile/utils/ocm/sre_capability_labels.py,sha256=nqh0imrYczNeeeC7ZNX3pEwuAIVk
|
|
736
736
|
reconcile/utils/ocm/status_board.py,sha256=8DYeIrOsW8Bh5PCtKdvGGpaxb9Wugcc5rLxZJ8Z7b_s,4181
|
737
737
|
reconcile/utils/ocm/subscriptions.py,sha256=hehKXsDXIhnhqvWOuiYvx6y2FGq3zt0APGYj7WiBIdI,2765
|
738
738
|
reconcile/utils/ocm/syncsets.py,sha256=9IQm1l5BodOVZa2OFbQmow3afmh4nXe5pn-CCJ5LxTI,1169
|
739
|
-
reconcile/utils/ocm/upgrades.py,sha256=
|
739
|
+
reconcile/utils/ocm/upgrades.py,sha256=UEgfSJuC8nH6jW9JjEx91_9QeeHR1UJ_9FVOX_PlvTU,4712
|
740
740
|
reconcile/utils/rosa/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
741
741
|
reconcile/utils/rosa/rosa_cli.py,sha256=bdr0fK8ARUxipLVTHehnCTxc6Kcgr8fV6k5I8FsDIhM,11335
|
742
742
|
reconcile/utils/rosa/session.py,sha256=FkhB2vS2Ke6WhZlzm-DWXd6pqD_PgrUJujdO9Nt4vJI,6869
|
@@ -796,7 +796,7 @@ tools/saas_promotion_state/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJ
|
|
796
796
|
tools/saas_promotion_state/saas_promotion_state.py,sha256=UfwwRLS5Ya4_Nh1w5n1dvoYtchQvYE9yj1VANt2IKqI,3925
|
797
797
|
tools/sre_checkpoints/__init__.py,sha256=CDaDaywJnmRCLyl_NCcvxi-Zc0hTi_3OdwKiFOyS39I,145
|
798
798
|
tools/sre_checkpoints/util.py,sha256=zEDbGr18ZeHNQwW8pUsr2JRjuXIPz--WAGJxZo9sv_Y,894
|
799
|
-
qontract_reconcile-0.10.2.
|
800
|
-
qontract_reconcile-0.10.2.
|
801
|
-
qontract_reconcile-0.10.2.
|
802
|
-
qontract_reconcile-0.10.2.
|
799
|
+
qontract_reconcile-0.10.2.dev254.dist-info/METADATA,sha256=JL26uYCyRE9kZHUhkJ6TTuKMhYTgYyffI1Pv4t9dJGY,23820
|
800
|
+
qontract_reconcile-0.10.2.dev254.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
801
|
+
qontract_reconcile-0.10.2.dev254.dist-info/entry_points.txt,sha256=5i9l54La3vQrDLAdwDKQWC0iG4sV9RRfOb1BpvzOWLc,698
|
802
|
+
qontract_reconcile-0.10.2.dev254.dist-info/RECORD,,
|
reconcile/aus/base.py
CHANGED
@@ -606,21 +606,27 @@ def fetch_current_state(
|
|
606
606
|
ocm_api, spec.cluster.id
|
607
607
|
)
|
608
608
|
for upgrade_policy in upgrade_policies:
|
609
|
-
|
610
|
-
|
609
|
+
policy = upgrade_policy | {
|
610
|
+
"cluster": spec.cluster,
|
611
|
+
}
|
612
|
+
current_state.append(ControlPlaneUpgradePolicy(**policy))
|
611
613
|
for node_pool in spec.node_pools:
|
612
614
|
node_upgrade_policies = get_node_pool_upgrade_policies(
|
613
615
|
ocm_api, spec.cluster.id, node_pool.id
|
614
616
|
)
|
615
617
|
for upgrade_policy in node_upgrade_policies:
|
616
|
-
|
617
|
-
|
618
|
-
|
618
|
+
policy = upgrade_policy | {
|
619
|
+
"cluster": spec.cluster,
|
620
|
+
"node_pool": node_pool.id,
|
621
|
+
}
|
622
|
+
current_state.append(NodePoolUpgradePolicy(**policy))
|
619
623
|
else:
|
620
624
|
upgrade_policies = get_upgrade_policies(ocm_api, spec.cluster.id)
|
621
625
|
for upgrade_policy in upgrade_policies:
|
622
|
-
|
623
|
-
|
626
|
+
policy = upgrade_policy | {
|
627
|
+
"cluster": spec.cluster,
|
628
|
+
}
|
629
|
+
current_state.append(ClusterUpgradePolicy(**policy))
|
624
630
|
|
625
631
|
return current_state
|
626
632
|
|
reconcile/aus/models.py
CHANGED
@@ -68,7 +68,13 @@ class ClusterUpgradeSpec(BaseModel):
|
|
68
68
|
return any(re.search(b, version) for b in self.blocked_versions)
|
69
69
|
|
70
70
|
def get_available_upgrades(self) -> list[str]:
|
71
|
-
|
71
|
+
cluster_available_upgrades = self.cluster.available_upgrades()
|
72
|
+
if (
|
73
|
+
self.oldest_current_version != self.current_version
|
74
|
+
and self.current_version not in cluster_available_upgrades
|
75
|
+
):
|
76
|
+
return [self.current_version, *cluster_available_upgrades]
|
77
|
+
return cluster_available_upgrades
|
72
78
|
|
73
79
|
@property
|
74
80
|
def effective_mutexes(self) -> set[str]:
|
reconcile/utils/ocm/upgrades.py
CHANGED
@@ -1,9 +1,30 @@
|
|
1
|
-
from typing import Any
|
1
|
+
from typing import Any, TypedDict
|
2
2
|
|
3
3
|
from reconcile.utils.ocm.base import OCMVersionGate
|
4
4
|
from reconcile.utils.ocm_base_client import OCMBaseClient
|
5
5
|
|
6
|
-
|
6
|
+
|
7
|
+
class UpgradePolicy(TypedDict):
|
8
|
+
id: str | None
|
9
|
+
next_run: str | None
|
10
|
+
schedule: str | None
|
11
|
+
schedule_type: str
|
12
|
+
state: str | None
|
13
|
+
version: str
|
14
|
+
|
15
|
+
|
16
|
+
def _build_upgrade_policy(
|
17
|
+
response: dict,
|
18
|
+
state: str | None,
|
19
|
+
) -> UpgradePolicy:
|
20
|
+
return UpgradePolicy(
|
21
|
+
id=response.get("id"),
|
22
|
+
schedule_type=response["schedule_type"],
|
23
|
+
schedule=response.get("schedule"),
|
24
|
+
next_run=response.get("next_run"),
|
25
|
+
version=response["version"],
|
26
|
+
state=state,
|
27
|
+
)
|
7
28
|
|
8
29
|
|
9
30
|
def build_cluster_url(cluster_id: str) -> str:
|
@@ -16,30 +37,25 @@ def build_cluster_url(cluster_id: str) -> str:
|
|
16
37
|
|
17
38
|
|
18
39
|
def get_upgrade_policies(
|
19
|
-
ocm_api: OCMBaseClient,
|
20
|
-
|
40
|
+
ocm_api: OCMBaseClient,
|
41
|
+
cluster_id: str,
|
42
|
+
) -> list[UpgradePolicy]:
|
21
43
|
"""Returns a list of details of Upgrade Policies
|
22
44
|
|
23
|
-
:param
|
45
|
+
:param ocm_api: OCM API client
|
46
|
+
:param cluster_id: cluster id
|
24
47
|
|
25
|
-
:
|
48
|
+
:return: list of UpgradePolicy
|
26
49
|
"""
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
):
|
32
|
-
if schedule_type and policy["schedule_type"] != schedule_type:
|
33
|
-
continue
|
34
|
-
policy_data = {
|
35
|
-
k: v for k, v in policy.items() if k in UPGRADE_POLICY_DESIRED_KEYS
|
36
|
-
}
|
37
|
-
policy_data["state"] = get_upgrade_policy_state(
|
38
|
-
ocm_api, cluster_id, policy["id"]
|
50
|
+
return [
|
51
|
+
_build_upgrade_policy(
|
52
|
+
policy,
|
53
|
+
state=get_upgrade_policy_state(ocm_api, cluster_id, policy["id"]),
|
39
54
|
)
|
40
|
-
|
41
|
-
|
42
|
-
|
55
|
+
for policy in ocm_api.get_paginated(
|
56
|
+
f"{build_cluster_url(cluster_id)}/upgrade_policies"
|
57
|
+
)
|
58
|
+
]
|
43
59
|
|
44
60
|
|
45
61
|
def get_upgrade_policy_state(
|
@@ -76,23 +92,21 @@ def delete_upgrade_policy(
|
|
76
92
|
|
77
93
|
|
78
94
|
def get_control_plane_upgrade_policies(
|
79
|
-
ocm_api: OCMBaseClient,
|
80
|
-
|
95
|
+
ocm_api: OCMBaseClient,
|
96
|
+
cluster_id: str,
|
97
|
+
) -> list[UpgradePolicy]:
|
81
98
|
"""
|
82
99
|
Returns a list of details of Upgrade Policies
|
83
100
|
"""
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
policy_data["state"] = policy.get("state", {}).get("value")
|
94
|
-
results.append(policy_data)
|
95
|
-
return results
|
101
|
+
return [
|
102
|
+
_build_upgrade_policy(
|
103
|
+
policy,
|
104
|
+
state=policy.get("state", {}).get("value"),
|
105
|
+
)
|
106
|
+
for policy in ocm_api.get_paginated(
|
107
|
+
f"{build_cluster_url(cluster_id)}/control_plane/upgrade_policies"
|
108
|
+
)
|
109
|
+
]
|
96
110
|
|
97
111
|
|
98
112
|
def create_control_plane_upgrade_policy(
|
@@ -124,18 +138,19 @@ def delete_control_plane_upgrade_policy(
|
|
124
138
|
|
125
139
|
def get_node_pool_upgrade_policies(
|
126
140
|
ocm_api: OCMBaseClient, cluster_id: str, node_pool: str
|
127
|
-
) -> list[
|
141
|
+
) -> list[UpgradePolicy]:
|
128
142
|
"""
|
129
143
|
Returns a list of details of Upgrade Policies
|
130
144
|
"""
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
145
|
+
return [
|
146
|
+
_build_upgrade_policy(
|
147
|
+
policy,
|
148
|
+
state=policy.get("state", {}).get("value"),
|
149
|
+
)
|
150
|
+
for policy in ocm_api.get_paginated(
|
151
|
+
f"{build_cluster_url(cluster_id)}/node_pools/{node_pool}/upgrade_policies"
|
152
|
+
)
|
153
|
+
]
|
139
154
|
|
140
155
|
|
141
156
|
def create_node_pool_upgrade_policy(
|
{qontract_reconcile-0.10.2.dev253.dist-info → qontract_reconcile-0.10.2.dev254.dist-info}/WHEEL
RENAMED
File without changes
|
File without changes
|