mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	This reverts commit 6220c445c4.
Thanks Adam Johnson and Márton Salomváry for reports.
			
			
This commit is contained in:
		| @@ -54,9 +54,6 @@ class LimitedStream(IOBase): | ||||
|  | ||||
|  | ||||
| class WSGIRequest(HttpRequest): | ||||
|     non_picklable_attrs = HttpRequest.non_picklable_attrs | frozenset(["environ"]) | ||||
|     meta_non_picklable_attrs = frozenset(["wsgi.errors", "wsgi.input"]) | ||||
|  | ||||
|     def __init__(self, environ): | ||||
|         script_name = get_script_name(environ) | ||||
|         # If PATH_INFO is empty (e.g. accessing the SCRIPT_NAME URL without a | ||||
| @@ -82,13 +79,6 @@ class WSGIRequest(HttpRequest): | ||||
|         self._read_started = False | ||||
|         self.resolver_match = None | ||||
|  | ||||
|     def __getstate__(self): | ||||
|         state = super().__getstate__() | ||||
|         for attr in self.meta_non_picklable_attrs: | ||||
|             if attr in state["META"]: | ||||
|                 del state["META"][attr] | ||||
|         return state | ||||
|  | ||||
|     def _get_scheme(self): | ||||
|         return self.environ.get("wsgi.url_scheme") | ||||
|  | ||||
|   | ||||
| @@ -55,8 +55,6 @@ class HttpRequest: | ||||
|     _encoding = None | ||||
|     _upload_handlers = [] | ||||
|  | ||||
|     non_picklable_attrs = frozenset(["resolver_match", "_stream"]) | ||||
|  | ||||
|     def __init__(self): | ||||
|         # WARNING: The `WSGIRequest` subclass doesn't call `super`. | ||||
|         # Any variable assignment made here should also happen in | ||||
| @@ -84,21 +82,6 @@ class HttpRequest: | ||||
|             self.get_full_path(), | ||||
|         ) | ||||
|  | ||||
|     def __getstate__(self): | ||||
|         obj_dict = self.__dict__.copy() | ||||
|         for attr in self.non_picklable_attrs: | ||||
|             if attr in obj_dict: | ||||
|                 del obj_dict[attr] | ||||
|         return obj_dict | ||||
|  | ||||
|     def __deepcopy__(self, memo): | ||||
|         obj = copy.copy(self) | ||||
|         for attr in self.non_picklable_attrs: | ||||
|             if hasattr(self, attr): | ||||
|                 setattr(obj, attr, copy.deepcopy(getattr(self, attr), memo)) | ||||
|         memo[id(self)] = obj | ||||
|         return obj | ||||
|  | ||||
|     @cached_property | ||||
|     def headers(self): | ||||
|         return HttpHeaders(self.META) | ||||
|   | ||||
| @@ -373,10 +373,12 @@ class HttpResponse(HttpResponseBase): | ||||
|         [ | ||||
|             "resolver_match", | ||||
|             # Non-picklable attributes added by test clients. | ||||
|             "asgi_request", | ||||
|             "client", | ||||
|             "context", | ||||
|             "json", | ||||
|             "templates", | ||||
|             "wsgi_request", | ||||
|         ] | ||||
|     ) | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user