diff options
| author | 2022-03-24 08:15:52 +0000 | |
|---|---|---|
| committer | 2022-03-31 20:53:41 +0100 | |
| commit | 2383754743b9a00d55c35e93efa5b14643ddd366 (patch) | |
| tree | edb1308c651d55301651cca12eefd3cadd6cc8af | |
| parent | Comment on what nitpick_ignore_regex does in conf.py (diff) | |
Mark async-rediscache as an optional extra dependency
Diffstat (limited to '')
| -rw-r--r-- | botcore/_bot.py | 15 | ||||
| -rw-r--r-- | poetry.lock | 37 | ||||
| -rw-r--r-- | pyproject.toml | 7 | 
3 files changed, 37 insertions, 22 deletions
| diff --git a/botcore/_bot.py b/botcore/_bot.py index d740fe03..d21ed6b9 100644 --- a/botcore/_bot.py +++ b/botcore/_bot.py @@ -1,13 +1,13 @@  import asyncio  import socket  import types +import warnings  from abc import abstractmethod  from contextlib import suppress  from typing import Optional  import aiohttp  import discord -from async_rediscache import RedisSession  from discord.ext import commands  from botcore.async_stats import AsyncStatsClient @@ -15,6 +15,11 @@ from botcore.site_api import APIClient  from botcore.utils._extensions import walk_extensions  from botcore.utils.logging import get_logger +try: +    from async_rediscache import RedisSession +except ImportError: +    RedisSession = discord.utils._MissingSentinel +  log = get_logger() @@ -57,7 +62,10 @@ class BotBase(commands.Bot):          self.guild_id = guild_id          self.http_session = http_session -        if redis_session: + +        if redis_session and RedisSession == discord.utils._MissingSentinel: +            warnings.warn("redis_session kwarg passed, but async-rediscache not installed!") +        elif redis_session:              self.redis_session = redis_session          self.api_client: Optional[APIClient] = None @@ -209,6 +217,7 @@ class BotBase(commands.Bot):          and :func:`ping_services`.          """          loop = asyncio.get_running_loop() +          self._connect_statsd(self.statsd_url, loop)          self.stats = AsyncStatsClient(loop, "127.0.0.1")          await self.stats.create_socket() @@ -256,7 +265,7 @@ class BotBase(commands.Bot):          if self.stats._transport:              self.stats._transport.close() -        if self.redis_session: +        if getattr(self.redis_session, None):              await self.redis_session.close()          if self._statsd_timerhandle: diff --git a/poetry.lock b/poetry.lock index dd607032..ac5d103e 100644 --- a/poetry.lock +++ b/poetry.lock @@ -23,7 +23,7 @@ name = "aioredis"  version = "2.0.1"  description = "asyncio (PEP 3156) Redis support"  category = "main" -optional = false +optional = true  python-versions = ">=3.6"  [package.dependencies] @@ -57,7 +57,7 @@ name = "async-rediscache"  version = "0.2.0"  description = "An easy to use asynchronous Redis cache"  category = "main" -optional = false +optional = true  python-versions = "~=3.7"  [package.dependencies] @@ -177,7 +177,7 @@ name = "deprecated"  version = "1.2.13"  description = "Python @deprecated decorator to deprecate old python classes, functions or methods."  category = "main" -optional = false +optional = true  python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"  [package.dependencies] @@ -238,7 +238,7 @@ name = "fakeredis"  version = "1.7.1"  description = "Fake implementation of redis API for testing purposes."  category = "main" -optional = false +optional = true  python-versions = ">=3.5"  [package.dependencies] @@ -466,11 +466,11 @@ python-versions = "*"  [[package]]  name = "jinja2" -version = "3.0.3" +version = "3.1.1"  description = "A very fast and expressive template engine."  category = "dev"  optional = false -python-versions = ">=3.6" +python-versions = ">=3.7"  [package.dependencies]  MarkupSafe = ">=2.0" @@ -483,7 +483,7 @@ name = "lupa"  version = "1.13"  description = "Python wrapper around Lua and LuaJIT"  category = "main" -optional = false +optional = true  python-versions = "*"  [[package]] @@ -755,7 +755,7 @@ name = "redis"  version = "4.1.4"  description = "Python client for Redis database and key-value store"  category = "main" -optional = false +optional = true  python-versions = ">=3.6"  [package.dependencies] @@ -813,7 +813,7 @@ name = "sortedcontainers"  version = "2.4.0"  description = "Sorted Containers -- Sorted List, Sorted Dict, Sorted Set"  category = "main" -optional = false +optional = true  python-versions = "*"  [[package]] @@ -985,7 +985,7 @@ name = "typing-extensions"  version = "4.1.1"  description = "Backported and Experimental Type Hints for Python 3.6+"  category = "main" -optional = false +optional = true  python-versions = ">=3.6"  [[package]] @@ -1003,7 +1003,7 @@ socks = ["PySocks (>=1.5.6,!=1.5.7,<2.0)"]  [[package]]  name = "virtualenv" -version = "20.13.4" +version = "20.14.0"  description = "Virtual Python Environment builder"  category = "dev"  optional = false @@ -1024,7 +1024,7 @@ name = "wrapt"  version = "1.14.0"  description = "Module for decorators, wrappers and monkey patching."  category = "main" -optional = false +optional = true  python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7"  [[package]] @@ -1051,10 +1051,13 @@ python-versions = ">=3.7"  docs = ["sphinx", "jaraco.packaging (>=8.2)", "rst.linker (>=1.9)"]  testing = ["pytest (>=6)", "pytest-checkdocs (>=2.4)", "pytest-flake8", "pytest-cov", "pytest-enabler (>=1.0.1)", "jaraco.itertools", "func-timeout", "pytest-black (>=0.3.7)", "pytest-mypy"] +[extras] +async-rediscache = ["async-rediscache"] +  [metadata]  lock-version = "1.1"  python-versions = "3.9.*" -content-hash = "00840d04789ee82c20b8c9633be5d2333427c2694850c457491cd9180fe39fa1" +content-hash = "d4ef1ae44135c6e669f1711cc55b04314d498d9c90c3329d8f5064d7a1b0ea4f"  [metadata.files]  aiohttp = [ @@ -1380,8 +1383,8 @@ iniconfig = [      {file = "iniconfig-1.1.1.tar.gz", hash = "sha256:bc3af051d7d14b2ee5ef9969666def0cd1a000e121eaea580d4a313df4b37f32"},  ]  jinja2 = [ -    {file = "Jinja2-3.0.3-py3-none-any.whl", hash = "sha256:077ce6014f7b40d03b47d1f1ca4b0fc8328a692bd284016f806ed0eaca390ad8"}, -    {file = "Jinja2-3.0.3.tar.gz", hash = "sha256:611bb273cd68f3b993fabdc4064fc858c5b47a973cb5aa7999ec1ba405c87cd7"}, +    {file = "Jinja2-3.1.1-py3-none-any.whl", hash = "sha256:539835f51a74a69f41b848a9645dbdc35b4f20a3b601e2d9a7e22947b15ff119"}, +    {file = "Jinja2-3.1.1.tar.gz", hash = "sha256:640bed4bb501cbd17194b3cace1dc2126f5b619cf068a726b98192a0fde74ae9"},  ]  lupa = [      {file = "lupa-1.13-cp27-cp27m-macosx_10_14_x86_64.whl", hash = "sha256:da1885faca29091f9e408c0cc6b43a0b29a2128acf8d08c188febc5d9f99129d"}, @@ -1788,8 +1791,8 @@ urllib3 = [      {file = "urllib3-1.26.9.tar.gz", hash = "sha256:aabaf16477806a5e1dd19aa41f8c2b7950dd3c746362d7e3223dbe6de6ac448e"},  ]  virtualenv = [ -    {file = "virtualenv-20.13.4-py2.py3-none-any.whl", hash = "sha256:c3e01300fb8495bc00ed70741f5271fc95fed067eb7106297be73d30879af60c"}, -    {file = "virtualenv-20.13.4.tar.gz", hash = "sha256:ce8901d3bbf3b90393498187f2d56797a8a452fb2d0d7efc6fd837554d6f679c"}, +    {file = "virtualenv-20.14.0-py2.py3-none-any.whl", hash = "sha256:1e8588f35e8b42c6ec6841a13c5e88239de1e6e4e4cedfd3916b306dc826ec66"}, +    {file = "virtualenv-20.14.0.tar.gz", hash = "sha256:8e5b402037287126e81ccde9432b95a8be5b19d36584f64957060a3488c11ca8"},  ]  wrapt = [      {file = "wrapt-1.14.0-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:5a9a1889cc01ed2ed5f34574c90745fab1dd06ec2eee663e8ebeefe363e8efd7"}, diff --git a/pyproject.toml b/pyproject.toml index d4d8ceb8..9626a2a9 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -17,8 +17,11 @@ exclude = ["tests", "tests.*"]  [tool.poetry.dependencies]  python = "3.9.*"  "discord.py" = {url = "https://github.com/Rapptz/discord.py/archive/414759f3723a3fe632ecfc1343a4164a51cd2940.zip"} -async-rediscache = { version = "0.2.0", extras = ["fakeredis"] } -statsd = "3.3.0" +async-rediscache = { version = "0.2.0", extras = ["fakeredis"], optional = true } +statsd  = "3.3.0" + +[tool.poetry.extras] +async-rediscache = ["async-rediscache"]  [tool.poetry.dev-dependencies]  flake8 = "4.0.1" | 
