2023-01-09 13:52:13 +01:00
|
|
|
From 5e3ff4d662321c237ddd5b2c5c83f35a84af594c Mon Sep 17 00:00:00 2001
|
2022-04-12 14:13:31 +02:00
|
|
|
From: Victor Zhestkov <vzhestkov@suse.com>
|
|
|
|
Date: Tue, 5 Apr 2022 12:04:46 +0300
|
|
|
|
Subject: [PATCH] Fixes for Python 3.10 (#502)
|
|
|
|
|
|
|
|
* Fix _compat.py importlib logic for Python 3.10
|
|
|
|
|
|
|
|
Use the same logic in _compat.py and entrypoints.py to load
|
|
|
|
the same importlib.metadata. Python's built in implementation for
|
|
|
|
Python >= 3.10 and the Salt one for others.
|
|
|
|
|
|
|
|
* Use collections.abc.Mapping instead collections.Mapping in state
|
|
|
|
|
|
|
|
Co-authored-by: piterpunk <piterpunk@slackware.com>
|
|
|
|
---
|
2023-01-09 13:52:13 +01:00
|
|
|
salt/_compat.py | 29 +++++++++++++++++------------
|
|
|
|
salt/state.py | 4 ++--
|
|
|
|
2 files changed, 19 insertions(+), 14 deletions(-)
|
2022-04-12 14:13:31 +02:00
|
|
|
|
|
|
|
diff --git a/salt/_compat.py b/salt/_compat.py
|
2023-01-09 13:52:13 +01:00
|
|
|
index ed404e877b..a402f17a3c 100644
|
2022-04-12 14:13:31 +02:00
|
|
|
--- a/salt/_compat.py
|
|
|
|
+++ b/salt/_compat.py
|
2023-01-09 13:52:13 +01:00
|
|
|
@@ -11,18 +11,23 @@ if sys.version_info >= (3, 9, 5):
|
2022-04-12 14:13:31 +02:00
|
|
|
else:
|
|
|
|
import salt.ext.ipaddress as ipaddress
|
|
|
|
|
2023-01-09 13:52:13 +01:00
|
|
|
-# importlib_metadata before version 3.3.0 does not include the functionality we need.
|
|
|
|
-try:
|
|
|
|
- import importlib_metadata
|
2022-04-12 14:13:31 +02:00
|
|
|
+if sys.version_info >= (3, 10):
|
|
|
|
+ # Python 3.10 will include a fix in importlib.metadata which allows us to
|
|
|
|
+ # get the distribution of a loaded entry-point
|
|
|
|
+ import importlib.metadata # pylint: disable=no-member,no-name-in-module
|
|
|
|
+else:
|
|
|
|
+ # importlib_metadata before version 3.3.0 does not include the functionality we need.
|
|
|
|
+ try:
|
|
|
|
+ import importlib_metadata
|
|
|
|
|
|
|
|
- importlib_metadata_version = [
|
|
|
|
- int(part)
|
|
|
|
- for part in importlib_metadata.version("importlib_metadata").split(".")
|
|
|
|
- if part.isdigit()
|
|
|
|
- ]
|
|
|
|
- if tuple(importlib_metadata_version) < (3, 3, 0):
|
|
|
|
+ importlib_metadata_version = [
|
|
|
|
+ int(part)
|
|
|
|
+ for part in importlib_metadata.version("importlib_metadata").split(".")
|
|
|
|
+ if part.isdigit()
|
|
|
|
+ ]
|
|
|
|
+ if tuple(importlib_metadata_version) < (3, 3, 0):
|
|
|
|
+ # Use the vendored importlib_metadata
|
|
|
|
+ import salt.ext.importlib_metadata as importlib_metadata
|
|
|
|
+ except ImportError:
|
|
|
|
# Use the vendored importlib_metadata
|
|
|
|
import salt.ext.importlib_metadata as importlib_metadata
|
|
|
|
-except ImportError:
|
|
|
|
- # Use the vendored importlib_metadata
|
|
|
|
- import salt.ext.importlib_metadata as importlib_metadata
|
|
|
|
diff --git a/salt/state.py b/salt/state.py
|
2023-01-09 13:52:13 +01:00
|
|
|
index f5579fbb69..9f3792fe5f 100644
|
2022-04-12 14:13:31 +02:00
|
|
|
--- a/salt/state.py
|
|
|
|
+++ b/salt/state.py
|
|
|
|
@@ -12,7 +12,6 @@ The data sent to the state calls is as follows:
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
-import collections
|
|
|
|
import copy
|
|
|
|
import datetime
|
|
|
|
import fnmatch
|
2023-01-09 13:52:13 +01:00
|
|
|
@@ -25,6 +24,7 @@ import site
|
|
|
|
import sys
|
2022-04-12 14:13:31 +02:00
|
|
|
import time
|
|
|
|
import traceback
|
|
|
|
+from collections.abc import Mapping
|
2023-01-09 13:52:13 +01:00
|
|
|
|
|
|
|
import salt.channel.client
|
2022-04-12 14:13:31 +02:00
|
|
|
import salt.fileclient
|
2023-01-09 13:52:13 +01:00
|
|
|
@@ -3405,7 +3405,7 @@ class State:
|
2022-04-12 14:13:31 +02:00
|
|
|
"""
|
|
|
|
for chunk in high:
|
|
|
|
state = high[chunk]
|
|
|
|
- if not isinstance(state, collections.Mapping):
|
|
|
|
+ if not isinstance(state, Mapping):
|
|
|
|
continue
|
|
|
|
for state_ref in state:
|
|
|
|
needs_default = True
|
|
|
|
--
|
2023-01-09 13:52:13 +01:00
|
|
|
2.37.3
|
2022-04-12 14:13:31 +02:00
|
|
|
|
|
|
|
|