add unit tests/refactoring
This commit is contained in:
		
							
								
								
									
										15
									
								
								sanic/app.py
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								sanic/app.py
									
									
									
									
									
								
							| @@ -14,7 +14,7 @@ from sanic.config import Config | ||||
| from sanic.constants import HTTP_METHODS | ||||
| from sanic.exceptions import ServerError, URLBuildError, SanicException | ||||
| from sanic.handlers import ErrorHandler | ||||
| from sanic.log import logger, error_logger | ||||
| from sanic.log import logger, error_logger, LOGGING_CONFIG_DEFAULTS | ||||
| from sanic.response import HTTPResponse, StreamingHTTPResponse | ||||
| from sanic.router import Router | ||||
| from sanic.server import serve, serve_multiple, HttpProtocol, Signal | ||||
| @@ -28,13 +28,16 @@ class Sanic: | ||||
|  | ||||
|     def __init__(self, name=None, router=None, error_handler=None, | ||||
|                  load_env=True, request_class=None, | ||||
|                  strict_slashes=False): | ||||
|                  strict_slashes=False, log_config=None): | ||||
|  | ||||
|         # Get name from previous stack frame | ||||
|         if name is None: | ||||
|             frame_records = stack()[1] | ||||
|             name = getmodulename(frame_records[1]) | ||||
|  | ||||
|         # logging | ||||
|         logging.config.dictConfig(log_config or LOGGING_CONFIG_DEFAULTS) | ||||
|  | ||||
|         self.name = name | ||||
|         self.router = router or Router() | ||||
|         self.request_class = request_class | ||||
| @@ -567,7 +570,7 @@ class Sanic: | ||||
|     def run(self, host=None, port=None, debug=False, ssl=None, | ||||
|             sock=None, workers=1, protocol=None, | ||||
|             backlog=100, stop_event=None, register_sys_signals=True, | ||||
|             access_log=True): | ||||
|             access_log=True, log_config=None): | ||||
|         """Run the HTTP Server and listen until keyboard interrupt or term | ||||
|         signal. On termination, drain connections before closing. | ||||
|  | ||||
| @@ -585,6 +588,8 @@ class Sanic: | ||||
|         :param protocol: Subclass of asyncio protocol class | ||||
|         :return: Nothing | ||||
|         """ | ||||
|         logging.config.dictConfig(log_config or LOGGING_CONFIG_DEFAULTS) | ||||
|  | ||||
|         if sock is None: | ||||
|             host, port = host or "127.0.0.1", port or 8000 | ||||
|  | ||||
| @@ -627,12 +632,14 @@ class Sanic: | ||||
|     async def create_server(self, host=None, port=None, debug=False, | ||||
|                             ssl=None, sock=None, protocol=None, | ||||
|                             backlog=100, stop_event=None, | ||||
|                             access_log=True): | ||||
|                             access_log=True, log_config=None): | ||||
|         """Asynchronous version of `run`. | ||||
|  | ||||
|         NOTE: This does not support multiprocessing and is not the preferred | ||||
|               way to run a Sanic application. | ||||
|         """ | ||||
|         logging.config.dictConfig(log_config or LOGGING_CONFIG_DEFAULTS) | ||||
|  | ||||
|         if sock is None: | ||||
|             host, port = host or "127.0.0.1", port or 8000 | ||||
|  | ||||
|   | ||||
| @@ -4,14 +4,8 @@ import syslog | ||||
| import platform | ||||
| import types | ||||
|  | ||||
| SANIC_PREFIX = 'SANIC_' | ||||
|  | ||||
| _address_dict = { | ||||
|     'Windows': ('localhost', 514), | ||||
|     'Darwin': '/var/run/syslog', | ||||
|     'Linux': '/dev/log', | ||||
|     'FreeBSD': '/var/run/log' | ||||
| } | ||||
| SANIC_PREFIX = 'SANIC_' | ||||
|  | ||||
|  | ||||
| class Config(dict): | ||||
|   | ||||
							
								
								
									
										15
									
								
								sanic/log.py
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								sanic/log.py
									
									
									
									
									
								
							| @@ -19,7 +19,7 @@ LOGGING_CONFIG_DEFAULTS = dict( | ||||
|  | ||||
|             "sanic.access": { | ||||
|                 "level": "INFO", | ||||
|                 "handlers": ["console"], | ||||
|                 "handlers": ["access_console"], | ||||
|                 "propagate": True, | ||||
|                 "qualname": "sanic.access" | ||||
|             } | ||||
| @@ -35,13 +35,24 @@ LOGGING_CONFIG_DEFAULTS = dict( | ||||
|                 "formatter": "generic", | ||||
|                 "stream": "sys.stderr" | ||||
|             }, | ||||
|             "access_console": { | ||||
|                 "class": "logging.StreamHandler", | ||||
|                 "formatter": "access", | ||||
|                 "stream": "sys.stdout" | ||||
|             }, | ||||
|         }, | ||||
|         formatters={ | ||||
|             "generic": { | ||||
|                 "format": "%(asctime)s [%(process)d] [%(levelname)s] %(message)s", | ||||
|                 "datefmt": "[%Y-%m-%d %H:%M:%S %z]", | ||||
|                 "class": "logging.Formatter" | ||||
|             } | ||||
|             }, | ||||
|             "access": { | ||||
|                 "format": "%(asctime)s - (%(name)s)[%(levelname)s][%(host)s]: " + | ||||
|                           "%(request)s %(message)s %(status)d %(byte)d", | ||||
|                 "datefmt": "[%Y-%m-%d %H:%M:%S %z]", | ||||
|                 "class": "logging.Formatter" | ||||
|             }, | ||||
|         } | ||||
| ) | ||||
|  | ||||
|   | ||||
| @@ -17,7 +17,7 @@ except ImportError: | ||||
|         json_loads = json.loads | ||||
|  | ||||
| from sanic.exceptions import InvalidUsage | ||||
| from sanic.log import logger | ||||
| from sanic.log import error_logger | ||||
|  | ||||
|  | ||||
| DEFAULT_HTTP_CONTENT_TYPE = "application/octet-stream" | ||||
| @@ -114,7 +114,7 @@ class Request(dict): | ||||
|                     self.parsed_form, self.parsed_files = ( | ||||
|                         parse_multipart_form(self.body, boundary)) | ||||
|             except Exception: | ||||
|                 logger.exception("Failed when parsing form") | ||||
|                 error_logger.exception("Failed when parsing form") | ||||
|  | ||||
|         return self.parsed_form | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Yun Xu
					Yun Xu