Skip to content

Commit

Permalink
Corrected Colors enum under Python 3.11
Browse files Browse the repository at this point in the history
  • Loading branch information
LiraNuna committed Oct 26, 2022
1 parent 6b9edfd commit 3f8c44a
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 2 deletions.
12 changes: 10 additions & 2 deletions sanic/log.py
Original file line number Diff line number Diff line change
@@ -1,12 +1,20 @@
import logging
import sys

from enum import Enum
from typing import Any, Dict
from warnings import warn

from sanic.compat import is_atty

# Python 3.11 changed the way Enum formatting works for mixed-in types.
if sys.version_info < (3, 11, 0):

class StrEnum(str, Enum):
pass

else:
from enum import StrEnum


LOGGING_CONFIG_DEFAULTS: Dict[str, Any] = dict( # no cov
version=1,
Expand Down Expand Up @@ -68,7 +76,7 @@
"""


class Colors(str, Enum): # no cov
class Colors(StrEnum): # no cov
END = "\033[0m"
BOLD = "\033[1m"
BLUE = "\033[34m"
Expand Down
12 changes: 12 additions & 0 deletions tests/test_logging.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import sanic

from sanic import Sanic
from sanic.log import Colors
from sanic.log import LOGGING_CONFIG_DEFAULTS, logger
from sanic.response import text

Expand Down Expand Up @@ -250,3 +251,14 @@ def log_info(request):

if app_verbosity == 0:
assert ("sanic.root", logging.INFO, "DEFAULT") in caplog.record_tuples


def test_colors_enum_format():
assert f'{Colors.END}' == Colors.END.value
assert f'{Colors.BOLD}' == Colors.BOLD.value
assert f'{Colors.BLUE}' == Colors.BLUE.value
assert f'{Colors.GREEN}' == Colors.GREEN.value
assert f'{Colors.PURPLE}' == Colors.PURPLE.value
assert f'{Colors.RED}' == Colors.RED.value
assert f'{Colors.SANIC}' == Colors.SANIC.value
assert f'{Colors.YELLOW}' == Colors.YELLOW.value

0 comments on commit 3f8c44a

Please sign in to comment.