Skip to content

Commit

Permalink
Fix OSError: [WinError 87] The parameter is incorrect (#1454)
Browse files Browse the repository at this point in the history
* Fix OSError: [WinError 87] The parameter is incorrect

* Added use_subprocess to be more generic

* Black

* Revert "Added use_subprocess to be more generic"

This reverts commit d1b5f83

* Removed reload warning

* Min diff, not sure where this came from

* Min diff 2

* Redo use_subprocess
  • Loading branch information
euri10 authored Jun 22, 2022
1 parent 81d647b commit 99ead36
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 8 deletions.
19 changes: 19 additions & 0 deletions tests/test_config.py
Original file line number Diff line number Diff line change
Expand Up @@ -544,3 +544,22 @@ def test_bind_fd_works_with_reload_or_workers(reload, workers): # pragma: py-wi
assert sock.getsockname() == ""
sock.close()
fdsock.close()


@pytest.mark.parametrize(
"reload, workers, expected",
[
(True, 1, True),
(False, 2, True),
(False, 1, False),
],
ids=[
"--reload=True --workers=1",
"--reload=False --workers=2",
"--reload=False --workers=1",
],
)
def test_config_use_subprocess(reload, workers, expected):
config = Config(app=asgi_app, reload=reload, workers=workers)
config.load()
assert config.use_subprocess == expected
6 changes: 5 additions & 1 deletion uvicorn/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -377,6 +377,10 @@ def asgi_version(self) -> Literal["2.0", "3.0"]:
def is_ssl(self) -> bool:
return bool(self.ssl_keyfile or self.ssl_certfile)

@property
def use_subprocess(self) -> bool:
return bool(self.reload or self.workers > 1)

def configure_logging(self) -> None:
logging.addLevelName(TRACE_LOG_LEVEL, "TRACE")

Expand Down Expand Up @@ -507,7 +511,7 @@ def load(self) -> None:
def setup_event_loop(self) -> None:
loop_setup: Optional[Callable] = import_from_string(LOOP_SETUPS[self.loop])
if loop_setup is not None:
loop_setup(reload=self.reload)
loop_setup(use_subprocess=self.use_subprocess)

def bind_socket(self) -> socket.socket:
logger_args: List[Union[str, int]]
Expand Down
5 changes: 2 additions & 3 deletions uvicorn/loops/asyncio.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
logger = logging.getLogger("uvicorn.error")


def asyncio_setup(reload: bool = False) -> None: # pragma: no cover
if sys.version_info >= (3, 8) and sys.platform == "win32" and reload:
logger.warning("The --reload flag should not be used in production on Windows.")
def asyncio_setup(use_subprocess: bool = False) -> None: # pragma: no cover
if sys.version_info >= (3, 8) and sys.platform == "win32" and use_subprocess:
asyncio.set_event_loop_policy(asyncio.WindowsSelectorEventLoopPolicy())
6 changes: 3 additions & 3 deletions uvicorn/loops/auto.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
def auto_loop_setup(reload: bool = False) -> None:
def auto_loop_setup(use_subprocess: bool = False) -> None:
try:
import uvloop # noqa
except ImportError: # pragma: no cover
from uvicorn.loops.asyncio import asyncio_setup as loop_setup

loop_setup(reload=reload)
loop_setup(use_subprocess=use_subprocess)
else: # pragma: no cover
from uvicorn.loops.uvloop import uvloop_setup

uvloop_setup(reload=reload)
uvloop_setup(use_subprocess=use_subprocess)
2 changes: 1 addition & 1 deletion uvicorn/loops/uvloop.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
import uvloop


def uvloop_setup(reload: bool = False) -> None:
def uvloop_setup(use_subprocess: bool = False) -> None:
asyncio.set_event_loop_policy(uvloop.EventLoopPolicy())

0 comments on commit 99ead36

Please sign in to comment.