Skip to content

Commit

Permalink
Get rid of pkg_resources
Browse files Browse the repository at this point in the history
... because it was removed in Python 3.12 [1].

[1] https://docs.python.org/3/whatsnew/3.12.html#ensurepip
  • Loading branch information
kajinamit committed Oct 4, 2024
1 parent a0d8267 commit 7c90f34
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 13 deletions.
6 changes: 3 additions & 3 deletions gnocchi/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import pkg_resources
import importlib.metadata

try:
__version__ = pkg_resources.get_distribution(__name__).version
except pkg_resources.DistributionNotFound:
__version__ = importlib.metadata.version('gnocchi')
except importlib.metadata.PackageNotFoundError:
# package is not installed
pass
21 changes: 14 additions & 7 deletions gnocchi/opts.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
import copy
import itertools
import operator
import pkg_resources
import sys
import uuid

from oslo_config import cfg
Expand All @@ -29,6 +29,11 @@
import gnocchi.storage.s3
import gnocchi.storage.swift

if sys.version_info < (3, 10, 0):
import importlib_metadata
else:
from importlib import metadata as importlib_metadata


# NOTE(sileht): The oslo.config interpolation is buggy when the value
# is None, this replaces it by the expected empty string.
Expand Down Expand Up @@ -178,12 +183,14 @@ def list_opts():
cfg.StrOpt('paste_config',
default="api-paste.ini",
help='Path to API Paste configuration.'),
cfg.StrOpt('auth_mode',
default="basic",
choices=list(map(operator.attrgetter("name"),
pkg_resources.iter_entry_points(
"gnocchi.rest.auth_helper"))),
help='Authentication mode to use.'),
cfg.StrOpt(
'auth_mode',
default="basic",
choices=list(map(
operator.attrgetter("name"),
importlib_metadata.entry_points(
group='gnocchi.rest.auth_helper'))),
help='Authentication mode to use.'),
cfg.IntOpt('max_limit',
default=1000,
help=('The maximum number of items returned in a '
Expand Down
5 changes: 2 additions & 3 deletions gnocchi/rest/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
# License for the specific language governing permissions and limitations
# under the License.
import os
import pkg_resources
import threading
import uuid

Expand Down Expand Up @@ -166,8 +165,8 @@ def load_app(conf, not_implemented_middleware=True):

if cfg_path is None or not os.path.exists(cfg_path):
LOG.debug("No api-paste configuration file found! Using default.")
cfg_path = os.path.abspath(pkg_resources.resource_filename(
__name__, "api-paste.ini"))
cfg_path = os.path.join(os.path.dirname(os.path.abspath(__file__)),
'api-paste.ini')

config = dict(conf=conf,
not_implemented_middleware=not_implemented_middleware)
Expand Down
1 change: 1 addition & 0 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ install_requires =
lz4>=0.9.0
tooz>=1.38
cachetools
importlib_metadata>=3.6; python_version<"3.10"

[options.extras_require]
keystone =
Expand Down

0 comments on commit 7c90f34

Please sign in to comment.