If HTTP response headers are already sent, don't fiddle with "zlib.output_compression"
Summary: We write some synthetic HTTP responses inside unit tests. Some responses have an indirect side effect of adjusting "zlib.output_compression", but this adjustment fails if headers have already been output. From a CLI context, headers appear to count as already-output after we write anything to stdout: ``` <?php echo headers_sent() ? "Y" : "N"; echo "\n"; echo headers_sent() ? "Y" : "N"; echo "\n"; ``` This script prints "N", then "Y". Recently, the default severity of warnings was increased in libphutil; this has been a long-standing warning but now causes test failures. This behavior is sort of silly but the whole thing is kind of moot anyway. Just skip it if "headers_sent()" is true. Test Plan: Ran "arc unit --everything", got clean results. Differential Revision: https://secure.phabricator.com/D21055
This commit is contained in:
		| @@ -417,6 +417,11 @@ abstract class AphrontResponse extends Phobject { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   public function willBeginWrite() { |   public function willBeginWrite() { | ||||||
|  |     // If we've already sent headers, these "ini_set()" calls will warn that | ||||||
|  |     // they have no effect. Today, this always happens because we're inside | ||||||
|  |     // a unit test, so just skip adjusting the setting. | ||||||
|  |  | ||||||
|  |     if (!headers_sent()) { | ||||||
|       if ($this->shouldCompressResponse()) { |       if ($this->shouldCompressResponse()) { | ||||||
|         // Enable automatic compression here. Webservers sometimes do this for |         // Enable automatic compression here. Webservers sometimes do this for | ||||||
|         // us, but we now detect the absence of compression and warn users about |         // us, but we now detect the absence of compression and warn users about | ||||||
| @@ -426,6 +431,7 @@ abstract class AphrontResponse extends Phobject { | |||||||
|         ini_set('zlib.output_compression', 0); |         ini_set('zlib.output_compression', 0); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   public function didCompleteWrite($aborted) { |   public function didCompleteWrite($aborted) { | ||||||
|     return; |     return; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley