Compare commits
	
		
			15 Commits
		
	
	
		
			v22.9.0
			...
			feat-2394-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 92bfeaefd5 | ||
|   | 5a650f5758 | ||
|   | 850b1f432c | ||
|   | df8480156d | ||
|   | d0cfb69f43 | ||
|   | 19eee8bfb2 | ||
|   | 625cffb1b9 | ||
|   | c5ac28cbcd | ||
|   | e57bea28f7 | ||
|   | 28665e31ce | ||
|   | 9f41936861 | ||
|   | 7835492b09 | ||
|   | ca3bea3425 | ||
|   | 88ca56dda3 | ||
|   | d2ab46d70b | 
| @@ -6,5 +6,5 @@ data = "" | ||||
| for i in range(1, 250000): | ||||
|     data += str(i) | ||||
|  | ||||
| r = requests.post('http://0.0.0.0:8000/stream', data=data) | ||||
| r = requests.post("http://0.0.0.0:8000/stream", data=data) | ||||
| print(r.text) | ||||
|   | ||||
| @@ -30,6 +30,7 @@ from types import SimpleNamespace | ||||
| from urllib.parse import parse_qs, parse_qsl, unquote, urlunparse | ||||
|  | ||||
| from httptools import parse_url  # type: ignore | ||||
| from httptools.parser.errors import HttpParserInvalidURLError # type: ignore | ||||
|  | ||||
| from sanic.compat import CancelledErrors, Header | ||||
| from sanic.constants import DEFAULT_HTTP_CONTENT_TYPE | ||||
| @@ -130,7 +131,12 @@ class Request: | ||||
|  | ||||
|         self.raw_url = url_bytes | ||||
|         # TODO: Content-Encoding detection | ||||
|         self._parsed_url = parse_url(url_bytes) | ||||
|         try: | ||||
|             self._parsed_url = parse_url(url_bytes) | ||||
|         except HttpParserInvalidURLError as InvalidURLError: | ||||
|             raise InvalidUsage( | ||||
|                 "URL is invalid or malformed" | ||||
|             ) from InvalidURLError | ||||
|         self._id: Optional[Union[uuid.UUID, str, int]] = None | ||||
|         self._name: Optional[str] = None | ||||
|         self.app = app | ||||
|   | ||||
| @@ -1,12 +1,26 @@ | ||||
| import asyncio | ||||
|  | ||||
| from distutils.util import strtobool | ||||
| from os import getenv | ||||
|  | ||||
| from sanic.compat import OS_IS_WINDOWS | ||||
| from sanic.log import error_logger | ||||
|  | ||||
|  | ||||
| def strtobool(query: str) -> bool: | ||||
|     """ | ||||
|     reimplement strtobool per PEP 632 and python 3.12 deprecation | ||||
|  | ||||
|     True values are y, yes, t, true, on and 1; false values are n, no, f, | ||||
|     false, off and 0. Raises ValueError if val is anything else. | ||||
|     """ | ||||
|     if query.lower() in ["y", "yes", "t", "true", "on", "1"]: | ||||
|         return True | ||||
|     elif query.lower() in ["n", "no", "f", "false", "off", "0"]: | ||||
|         return False | ||||
|     else: | ||||
|         raise ValueError(f"String value {query} cannot be converted to bool") | ||||
|  | ||||
|  | ||||
| def try_use_uvloop() -> None: | ||||
|     """ | ||||
|     Use uvloop instead of the default asyncio loop. | ||||
|   | ||||
| @@ -11,35 +11,18 @@ from sanic.helpers import import_string | ||||
|  | ||||
|  | ||||
| def str_to_bool(val: str) -> bool: | ||||
|     """Takes string and tries to turn it into bool as human would do. | ||||
|     """ | ||||
|     reimplement strtobool per PEP 632 and python 3.12 deprecation | ||||
|  | ||||
|     If val is in case insensitive ( | ||||
|         "y", "yes", "yep", "yup", "t", | ||||
|         "true", "on", "enable", "enabled", "1" | ||||
|     ) returns True. | ||||
|     If val is in case insensitive ( | ||||
|         "n", "no", "f", "false", "off", "disable", "disabled", "0" | ||||
|     ) returns False. | ||||
|     Else Raise ValueError.""" | ||||
|  | ||||
|     val = val.lower() | ||||
|     if val in { | ||||
|         "y", | ||||
|         "yes", | ||||
|         "yep", | ||||
|         "yup", | ||||
|         "t", | ||||
|         "true", | ||||
|         "on", | ||||
|         "enable", | ||||
|         "enabled", | ||||
|         "1", | ||||
|     }: | ||||
|     True values are y, yes, t, true, on and 1; false values are n, no, f, | ||||
|     false, off and 0. Raises ValueError if val is anything else. | ||||
|     """ | ||||
|     if val.lower() in ["y", "yes", "t", "true", "on", "1"]: | ||||
|         return True | ||||
|     elif val in {"n", "no", "f", "false", "off", "disable", "disabled", "0"}: | ||||
|     elif val.lower() in ["n", "no", "f", "false", "off", "0"]: | ||||
|         return False | ||||
|     else: | ||||
|         raise ValueError(f"Invalid truth value {val}") | ||||
|         raise ValueError(f"String value {val} cannot be converted to bool") | ||||
|  | ||||
|  | ||||
| def load_module_from_file_location( | ||||
|   | ||||
							
								
								
									
										21
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								setup.py
									
									
									
									
									
								
							| @@ -6,8 +6,6 @@ import os | ||||
| import re | ||||
| import sys | ||||
|  | ||||
| from distutils.util import strtobool | ||||
|  | ||||
| from setuptools import find_packages, setup | ||||
| from setuptools.command.test import test as TestCommand | ||||
|  | ||||
| @@ -61,7 +59,7 @@ setup_kwargs = { | ||||
|         "Build fast. Run fast." | ||||
|     ), | ||||
|     "long_description": long_description, | ||||
|     "packages": find_packages(), | ||||
|     "packages": find_packages(include=[]), | ||||
|     "package_data": {"sanic": ["py.typed"]}, | ||||
|     "platforms": "any", | ||||
|     "python_requires": ">=3.7", | ||||
| @@ -132,6 +130,23 @@ dev_require = tests_require + [ | ||||
|  | ||||
| all_require = list(set(dev_require + docs_require)) | ||||
|  | ||||
| # trying to self-refernce this from within sanic prior to install is | ||||
| # problematic | ||||
| def strtobool(val: str) -> bool: | ||||
|     """ | ||||
|     reimplement strtobool per PEP 632 and python 3.12 deprecation | ||||
|  | ||||
|     True values are y, yes, t, true, on and 1; false values are n, no, f, | ||||
|     false, off and 0. Raises ValueError if val is anything else. | ||||
|     """ | ||||
|     if val.lower() in ["y", "yes", "t", "true", "on", "1"]: | ||||
|         return True | ||||
|     elif val.lower() in ["n", "no", "f", "false", "off", "0"]: | ||||
|         return False | ||||
|     else: | ||||
|         raise ValueError(f"String value {val} cannot be converted to bool") | ||||
|  | ||||
|  | ||||
| if strtobool(os.environ.get("SANIC_NO_UJSON", "no")): | ||||
|     print("Installing without uJSON") | ||||
|     requirements.remove(ujson) | ||||
|   | ||||
| @@ -21,3 +21,25 @@ def test_bad_request_response(app): | ||||
|     app.run(host="127.0.0.1", port=42101, debug=False) | ||||
|     assert lines[0] == b"HTTP/1.1 400 Bad Request\r\n" | ||||
|     assert b"Bad Request" in lines[-2] | ||||
|  | ||||
|  | ||||
| def test_malformed_uri_bad_request(app): | ||||
|     lines = [] | ||||
|  | ||||
|     app.get("/")(lambda x: ...) | ||||
|  | ||||
|     @app.listener("after_server_start") | ||||
|     async def _request(sanic, loop): | ||||
|         connect = asyncio.open_connection("127.0.0.1", 42101) | ||||
|         reader, writer = await connect | ||||
|         writer.write(b"GET /\r\nHost: ---.com\r\n\r\n") | ||||
|         while True: | ||||
|             line = await reader.readline() | ||||
|             if not line: | ||||
|                 break | ||||
|             lines.append(line) | ||||
|         app.stop() | ||||
|  | ||||
|     app.run(host="127.0.0.1", port=42101, debug=False) | ||||
|     assert lines[0] == b"HTTP/1.1 400 Bad Request\r\n" | ||||
|     assert b"Bad Request" in lines[-2] | ||||
| @@ -6,6 +6,7 @@ import pytest | ||||
|  | ||||
| from sanic.exceptions import LoadFileException | ||||
| from sanic.utils import load_module_from_file_location | ||||
| from sanic.utils import str_to_bool as strtobool | ||||
|  | ||||
|  | ||||
| @pytest.mark.parametrize( | ||||
| @@ -48,3 +49,20 @@ def test_load_module_from_file_location_using_env(): | ||||
|     module = load_module_from_file_location(location) | ||||
|  | ||||
|     assert isinstance(module, ModuleType) | ||||
|  | ||||
|  | ||||
| @pytest.mark.parametrize( | ||||
|     "valid,values", | ||||
|     ( | ||||
|         (True, ["y", "yes", "t", "true", "on", "1", "Y", "yEs", "True"]), | ||||
|         (False, ["n", "no", "f", "false", "off", "0", "N", "No", "False"]), | ||||
|         (None, ["yyy", "foo"]), | ||||
|     ), | ||||
| ) | ||||
| def test_strtobool(valid, values): | ||||
|     for value in values: | ||||
|         if valid is None: | ||||
|             with pytest.raises(ValueError): | ||||
|                 strtobool(value) | ||||
|         else: | ||||
|             assert strtobool(value) is valid | ||||
|   | ||||
		Reference in New Issue
	
	Block a user