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() { | ||||
|     // 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()) { | ||||
|         // Enable automatic compression here. Webservers sometimes do this for | ||||
|         // 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); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   public function didCompleteWrite($aborted) { | ||||
|     return; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley